.page-container{margin:0 auto;padding:0 2rem;width:100%}.page-wrapper{background:var(--bg-primary);min-height:100vh;padding-bottom:3rem;padding-top:80px}.section-spacing{margin-bottom:3rem}.section-spacing-large{margin-bottom:4rem}.premium-card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:20px;box-shadow:0 8px 32px var(--card-shadow);overflow:hidden;padding:2rem;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1)}.premium-card:before{background:var(--gradient-primary);content:"";height:3px;left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .3s}.premium-card:hover{border-color:var(--primary-color);box-shadow:0 12px 48px var(--card-shadow);transform:translateY(-4px)}.premium-card:hover:before{opacity:1}.glass-card{backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:var(--bg-glass-light);border:1px solid var(--border-glass-light);border-radius:20px;box-shadow:0 8px 32px var(--card-shadow);padding:2rem}.gradient-bg-primary{background:var(--gradient-primary)}.gradient-bg-secondary{background:linear-gradient(135deg,var(--secondary-color) 0,var(--primary-color) 100%)}.gradient-bg-success{background:linear-gradient(135deg,var(--success-color) 0,var(--success-hover) 100%)}.gradient-bg-danger{background:linear-gradient(135deg,var(--error-color) 0,var(--error-hover) 100%)}.grid-2{grid-gap:2rem;grid-template-columns:repeat(2,1fr)}.grid-2,.grid-3{display:grid;gap:2rem}.grid-3{grid-gap:2rem;grid-template-columns:repeat(3,1fr)}.grid-4{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(4,1fr)}.grid-auto-fit{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}@media (max-width:1024px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.page-container{padding:0 1rem}}.btn-modern{align-items:center;border:none;border-radius:12px;cursor:pointer;display:inline-flex;font-size:.95rem;font-weight:600;gap:.5rem;outline:none;padding:.75rem 1.5rem;transition:all .3s}.btn-primary{box-shadow:0 4px 12px var(--primary-shadow-md)}.btn-primary:hover{box-shadow:0 6px 20px var(--primary-shadow-hover)}.btn-secondary:hover{border-color:var(--primary-color)}.stat-card{border:1px solid var(--card-border);border-radius:16px;transition:all .3s}.stat-card:hover{box-shadow:0 8px 24px var(--card-shadow)}.stat-value{gap:.5rem}.stat-change{align-items:center;display:flex;font-size:.875rem;font-weight:600;gap:.25rem;margin-top:.5rem}.stat-change.positive{color:var(--success-color)}.stat-change.negative{color:var(--error-color)}.animate-fade-in{animation:fadeIn .6s ease-out}.animate-fade-in-up{animation:fadeInUp .6s ease-out}.animate-slide-in-right{animation:slideInRight .6s ease-out}.stagger-children>*{animation:fadeInUp .6s ease-out}.stagger-children>:first-child{animation-delay:.1s}.stagger-children>:nth-child(2){animation-delay:.2s}.stagger-children>:nth-child(3){animation-delay:.3s}.stagger-children>:nth-child(4){animation-delay:.4s}.stagger-children>:nth-child(5){animation-delay:.5s}.stagger-children>:nth-child(6){animation-delay:.6s}.skeleton{animation:loading 1.5s ease-in-out infinite;background:linear-gradient(90deg,var(--bg-secondary) 25%,var(--bg-hover) 50%,var(--bg-secondary) 75%);border-radius:8px}@keyframes loading{0%{background-position:200% 0}to{background-position:-200% 0}}.text-gradient{-webkit-text-fill-color:#0000;background:var(--gradient-primary);-webkit-background-clip:text;background-clip:text}.flex-center{justify-content:center}.flex-between,.flex-center{align-items:center;display:flex}.flex-between{justify-content:space-between}.gap-1{gap:.5rem}.gap-2{gap:1rem}.gap-3{gap:1.5rem}.gap-4{gap:2rem}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bg-primary);color:var(--text-primary);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.6}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}::-webkit-scrollbar-track{background:var(--bg-tertiary)}::-webkit-scrollbar-thumb{background:var(--border-color-dark)}::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}.container{padding:0 clamp(.75rem,2vw,1.5rem)}@media (max-width:768px){.container{padding:0 clamp(.5rem,2vw,1rem)}}@media (max-width:480px){.container{padding:0 clamp(.5rem,2vw,.75rem)}}.technical-dashboard-new,.technical-dashboard-new .container{margin:0!important;max-width:100%!important;padding:0!important;width:100vw!important}.btn{display:inline-flex;padding:.75rem 1.5rem;text-decoration:none;transition:all .2s ease}.btn-primary{background-color:var(--primary-color);color:var(--text-inverse)}.btn-primary:hover{background-color:var(--primary-hover)}.btn-secondary{color:var(--text-inverse)}.btn-secondary,.btn-secondary:hover{background-color:var(--text-tertiary)}.btn-secondary:hover{opacity:.9}.card{border-radius:.75rem;box-shadow:0 1px 3px 0 var(--card-shadow),0 1px 2px 0 var(--card-shadow);margin-bottom:1rem}.text-center{text-align:center}.text-green{color:var(--success-color)}.text-red{color:var(--error-color)}.text-gray{color:var(--text-secondary)}.font-bold{font-weight:700}.font-semibold{font-weight:600}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.grid{grid-gap:1rem;display:grid;gap:1rem}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}@media (min-width:768px){.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.md\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}}@media (min-width:1024px){.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.lg\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}}.toast{align-items:center;animation:slideInRight .3s ease-out;background:var(--card-bg);border-left:4px solid;border:1px solid var(--card-border);border-radius:8px;box-shadow:0 4px 12px var(--card-shadow-hover);display:flex;justify-content:space-between;margin-bottom:.75rem;max-width:500px;min-width:300px;overflow:hidden;padding:1rem 1.25rem;position:relative}.toast-exiting{animation:slideOutRight .3s ease-in forwards}@keyframes slideInRight{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}@keyframes slideOutRight{0%{opacity:1;transform:translateX(0)}to{opacity:0;transform:translateX(100%)}}.toast-info{border-left-color:var(--info-color)}.toast-success{border-left-color:var(--success-color)}.toast-warning{border-left-color:var(--warning-color)}.toast-error{border-left-color:var(--error-color)}.toast-content{align-items:center;display:flex;flex:1 1;gap:.75rem}.toast-icon{flex-shrink:0;height:20px;width:20px}.toast-icon-info{color:var(--info-color)}.toast-icon-success{color:var(--success-color)}.toast-icon-warning{color:var(--warning-color)}.toast-icon-error{color:var(--error-color)}.toast-message{color:var(--text-primary);font-size:.875rem;line-height:1.5}.toast-close{align-items:center;background:none;border:none;border-radius:4px;color:var(--text-secondary);cursor:pointer;display:flex;flex-shrink:0;justify-content:center;margin-left:.75rem;padding:.25rem;transition:all .2s}.toast-close:hover{background:var(--bg-secondary);color:var(--text-primary)}@media (max-width:640px){.toast{max-width:calc(100vw - 2rem);min-width:auto}}.toast-container{align-items:flex-end;display:flex;flex-direction:column;pointer-events:none;position:fixed;right:1rem;top:1rem;z-index:10000}.toast-container>*{pointer-events:auto}@media (max-width:640px){.toast-container{align-items:stretch;left:.5rem;right:.5rem;top:.5rem}}.tools-box{display:inline-block;position:relative}.tools-box-button{align-items:center;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);cursor:pointer;display:flex;height:36px;justify-content:center;padding:.5rem;transition:all .2s ease;width:36px}.tools-box-button:hover{background:var(--bg-hover);border-color:var(--border-color-dark);color:var(--primary-color)}.tools-box-button:focus{box-shadow:0 0 0 3px var(--primary-light);outline:none}.tools-box-dropdown{animation:dropdownFadeIn .2s ease;background:var(--card-bg);border:1px solid var(--card-border);border-radius:12px;box-shadow:0 10px 40px var(--card-shadow-hover);min-width:220px;overflow:hidden;position:absolute;right:0;top:calc(100% + .5rem);z-index:1000}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.tools-section{padding:.75rem 0}.tools-section-header{align-items:center;border-bottom:1px solid var(--border-color-light);color:var(--text-secondary);display:flex;font-size:.75rem;font-weight:600;gap:.5rem;letter-spacing:.05em;margin-bottom:.25rem;padding:.5rem 1rem;text-transform:uppercase}.tools-section-content{display:flex;flex-direction:column;gap:.25rem;padding:.25rem 0}.tools-option{align-items:center;background:#0000;border:none;color:var(--text-primary);cursor:pointer;display:flex;font-size:.875rem;gap:.75rem;padding:.625rem 1rem;text-align:left;transition:all .2s ease;width:100%}.tools-option:hover{background:var(--bg-hover);color:var(--primary-color)}.tools-option.active{background:var(--primary-light);color:var(--primary-color);font-weight:500}.tools-option-icon{color:var(--text-secondary);flex-shrink:0}.tools-option.active .tools-option-icon{color:var(--primary-color)}.tools-option-flag{flex-shrink:0;font-size:1.125rem}.tools-option-name{flex:1 1}.tools-option-check{color:var(--primary-color);flex-shrink:0;font-weight:600}.tools-divider{background:var(--border-color-light);height:1px;margin:.5rem 0}@media (max-width:768px){.tools-box-dropdown{left:0;min-width:200px;right:auto}}.navbar{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:var(--navbar-bg);border-bottom:1px solid var(--navbar-border);left:0;padding:0;position:fixed;right:0;top:0;transition:all .3s ease;z-index:1000}.navbar .container{max-width:100%;padding-left:1rem;padding-right:1rem}.navbar-content{flex-wrap:nowrap;gap:2rem;justify-content:space-between;padding:1rem 0;width:100%}.navbar-brand,.navbar-content{align-items:center;display:flex}.navbar-brand{color:var(--navbar-text);flex-shrink:0;font-size:1.5rem;font-weight:700;margin-left:0;margin-right:auto;text-decoration:none;transition:color .2s ease;white-space:nowrap}.brand-icon,.navbar-brand:hover{color:var(--primary-color)}.brand-icon{margin-right:.5rem}.brand-text{-webkit-text-fill-color:#0000;background:var(--gradient-primary);-webkit-background-clip:text;background-clip:text;white-space:nowrap}.desktop-nav{flex:1 1;flex-wrap:nowrap;justify-content:center;margin:0 auto;min-width:0}.desktop-nav,.nav-link{align-items:center;display:flex;gap:.5rem}.nav-link{border-radius:.5rem;color:var(--text-secondary);flex-shrink:0;font-size:.875rem;font-weight:500;line-height:1.4;padding:.5rem .75rem;position:relative;text-decoration:none;transition:all .2s ease;white-space:nowrap}.nav-link:hover{background-color:var(--navbar-hover);color:var(--primary-color)}.nav-link.active{background-color:var(--primary-light);color:var(--primary-color)}.nav-link.active:after{background-color:var(--primary-color);border-radius:50%;bottom:-1rem;content:"";height:4px;left:50%;position:absolute;transform:translateX(-50%);width:4px}.nav-icon{flex-shrink:0;height:18px;width:18px}.mobile-menu-btn{background:none;border:none;border-radius:.5rem;color:var(--text-secondary);cursor:pointer;display:none;padding:.5rem;transition:all .2s ease}.mobile-menu-btn:hover{background-color:var(--navbar-hover);color:var(--primary-color)}.mobile-nav{border-top:1px solid var(--border-color);display:none;flex-direction:column;gap:.5rem;max-height:0;overflow:hidden;padding:1rem 0;transition:max-height .3s ease}.mobile-nav.open{max-height:400px}.mobile-nav-link{align-items:center;border-radius:.5rem;color:var(--text-secondary);display:flex;font-weight:500;gap:.75rem;padding:.75rem 1rem;text-decoration:none;transition:all .2s ease}.mobile-nav-link:hover{background-color:var(--navbar-hover);color:var(--primary-color)}.mobile-nav-link.active{background-color:var(--primary-light);color:var(--primary-color)}.notification-btn{align-items:center;background:var(--card-bg);border:2px solid var(--border-color);border-radius:.5rem;color:var(--text-secondary);cursor:pointer;display:flex;font-size:.9rem;font-weight:500;gap:.5rem;padding:.5rem 1rem;transition:all .2s ease}.notification-btn:hover{background-color:var(--bg-secondary);border-color:var(--info-color);color:var(--info-color)}.notification-btn:disabled{cursor:not-allowed;opacity:.6}.notification-btn.success{background-color:var(--success-light);border-color:var(--success-color);color:var(--success-color)}.notification-btn.error{background-color:var(--error-light);border-color:var(--error-color);color:var(--error-color)}.mobile-notification-btn{align-items:center;background:var(--card-bg);border:2px solid var(--border-color);border-radius:.5rem;color:var(--text-secondary);cursor:pointer;display:flex;font-weight:500;gap:.75rem;justify-content:flex-start;margin-top:.5rem;padding:.75rem 1rem;transition:all .2s ease;width:100%}.mobile-notification-btn:hover{background-color:var(--bg-secondary);border-color:var(--info-color);color:var(--info-color)}.mobile-notification-btn:disabled{cursor:not-allowed;opacity:.6}.mobile-notification-btn.success{background-color:var(--success-light);border-color:var(--success-color);color:var(--success-color)}.mobile-notification-btn.error{background-color:var(--error-light);border-color:var(--error-color);color:var(--error-color)}.navbar-right{align-items:center;display:flex;flex-shrink:0;gap:.75rem;margin-left:auto;margin-right:0}.navbar-clock{margin-right:.25rem}.navbar-right .nav-link{margin:0}.nav-link-text{display:inline}@media (max-width:1200px){.nav-link-text{display:none}.navbar-right .nav-link{justify-content:center;min-width:40px;padding:.5rem}}.user-menu{flex-shrink:0;gap:.75rem}.user-info,.user-menu{align-items:center;display:flex}.user-info{color:var(--text-secondary);font-size:.875rem;gap:.5rem;text-decoration:none;transition:all .2s ease}.user-info.clickable{border-radius:.5rem;cursor:pointer;padding:.5rem;transition:all .2s ease}.user-info.clickable:hover{background:var(--bg-tertiary);color:var(--info-color);transform:translateY(-1px)}.user-name{max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.logout-btn{align-items:center;background:var(--error-color);border:none;border-radius:.5rem;color:#fff;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;padding:.5rem .875rem;transition:all .2s ease;white-space:nowrap}.logout-btn:hover:not(:disabled){background:var(--error-color);filter:brightness(.9);transform:translateY(-1px)}.logout-btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.auth-buttons{flex-shrink:0}.auth-buttons,.login-btn{align-items:center;display:flex;gap:.5rem}.login-btn{background:var(--info-color);border-radius:.5rem;color:#fff;font-size:.875rem;font-weight:500;padding:.5rem .875rem;text-decoration:none;transition:all .2s ease;white-space:nowrap}.login-btn:hover{background:var(--primary-hover);transform:translateY(-1px)}.register-btn{background:#0000;border:2px solid var(--info-color);border-radius:.5rem;color:var(--info-color);font-size:.875rem;font-weight:500;padding:.5rem .875rem;text-decoration:none;transition:all .2s ease;white-space:nowrap}.register-btn:hover{background:var(--info-color);color:#fff;transform:translateY(-1px)}.mobile-user-info{align-items:center;border-bottom:1px solid var(--border-color);color:var(--text-secondary);display:flex;font-size:.875rem;gap:.5rem;padding:.75rem 1rem;text-decoration:none;transition:all .2s ease}.mobile-user-info.clickable{cursor:pointer;transition:all .2s ease}.mobile-user-info.clickable:hover{background:var(--navbar-hover);color:var(--primary-color)}.mobile-logout-btn{align-items:center;background:var(--error-color);border:none;color:#fff;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;padding:.75rem 1rem;transition:all .2s ease;width:100%}.mobile-logout-btn:hover:not(:disabled){background:var(--error-color);filter:brightness(.9)}.mobile-logout-btn:disabled{cursor:not-allowed;opacity:.6}.mobile-auth-buttons{border-top:1px solid var(--border-color);display:flex;flex-direction:column;gap:.5rem;padding:1rem}.mobile-login-btn{align-items:center;background:var(--info-color);border-radius:.5rem;color:#fff;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;justify-content:center;padding:.75rem 1rem;text-decoration:none;transition:all .2s ease}.mobile-login-btn:hover{background:var(--primary-hover)}.mobile-register-btn{align-items:center;background:#0000;border:2px solid var(--info-color);border-radius:.5rem;color:var(--info-color);display:flex;font-size:.875rem;font-weight:500;justify-content:center;padding:.75rem 1rem;text-decoration:none;transition:all .2s ease}.mobile-register-btn:hover{background:var(--info-color);color:#fff}@media (max-width:1024px){.desktop-nav{gap:.375rem}.nav-link{font-size:.8125rem;padding:.5rem .625rem}.user-name{max-width:80px}}@media (max-width:768px){.desktop-nav{display:none}.mobile-menu-btn{display:block}.mobile-nav{display:flex}.navbar-content{padding:.75rem 0}.brand-text{font-size:1.25rem}}@media (max-width:480px){.container{padding:0 .75rem}.brand-text{font-size:1.1rem}.nav-link{font-size:.9rem;padding:.4rem .8rem}}.nav-dropdown{position:relative}.dropdown-trigger{align-items:center;cursor:pointer;display:flex;gap:8px;-webkit-user-select:none;user-select:none}.dropdown-arrow{transition:transform .2s ease}.nav-dropdown.open .dropdown-arrow,.nav-dropdown:hover .dropdown-arrow{transform:rotate(180deg)}.dropdown-menu{animation:slideDown .2s ease;background:var(--card-bg);border:1px solid var(--border-color);border-radius:10px;box-shadow:0 10px 25px var(--card-shadow-hover);left:0;min-width:240px;padding:8px 0;pointer-events:auto;position:absolute;top:calc(100% + 8px);z-index:1001}.dropdown-item{align-items:center;color:var(--text-secondary);display:flex;font-size:.9375rem;font-weight:500;padding:12px 20px;text-decoration:none;transition:all .15s ease;white-space:nowrap}.dropdown-item:hover{background:var(--navbar-hover);color:var(--primary-color);padding-left:24px}.dropdown-item.active{background:var(--primary-light);border-left:3px solid var(--primary-color);color:var(--primary-color);font-weight:600}.mobile-dropdown{display:flex;flex-direction:column}.mobile-dropdown-header{align-items:center;border-bottom:1px solid var(--border-color);color:var(--text-secondary);display:flex;font-weight:600;gap:12px;padding:12px 20px}.mobile-dropdown-items{background:var(--bg-secondary);display:flex;flex-direction:column}.mobile-nav-link.sub-item{font-size:.9rem;padding-left:52px}.search-stocks{margin:0 auto;max-width:1200px;padding:2rem}.search-header{margin-bottom:2rem;text-align:center}.search-header h2{align-items:center;color:var(--text-primary);display:flex;font-size:2rem;font-weight:700;gap:.5rem;justify-content:center;margin-bottom:.5rem}.search-header p{color:var(--text-secondary);font-size:1.1rem}.search-input-container{margin-bottom:2rem}.search-input-wrapper{margin:0 auto;max-width:600px;position:relative}.search-icon{color:var(--text-secondary);left:1rem;position:absolute;top:50%;transform:translateY(-50%)}.search-input{background:var(--card-bg);border:2px solid var(--border-color);border-radius:.75rem;padding:1rem 1rem 1rem 3rem;transition:all .2s ease;width:100%}.search-input:focus{border-color:var(--info-color);box-shadow:0 0 0 3px var(--info-light);outline:none}.error-message{margin-bottom:1rem}.loading-message{color:var(--text-secondary);font-size:1.1rem;padding:2rem;text-align:center}.search-results{margin-bottom:2rem}.search-results h3{color:var(--text-primary);font-size:1.5rem;font-weight:600;margin-bottom:1rem}.results-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.result-card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:.75rem;cursor:pointer;padding:1.5rem;transition:all .2s ease}.result-card:hover{border-color:var(--info-color);box-shadow:0 4px 12px var(--card-shadow-hover);transform:translateY(-2px)}.result-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.5rem}.stock-symbol{color:var(--text-primary);font-size:1.1rem;font-weight:700}.stock-exchange{background:var(--bg-tertiary);border-radius:.25rem;color:var(--text-secondary);font-size:.8rem;font-weight:500;padding:.25rem .5rem}.stock-name{color:var(--text-primary);font-weight:600;margin-bottom:.25rem}.stock-type{color:var(--text-secondary);font-size:.9rem}.stock-details{margin-top:2rem}.stock-details h3{color:var(--text-primary);font-size:1.5rem;font-weight:600;margin-bottom:1rem}.details-card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:1rem;box-shadow:0 4px 6px var(--card-shadow);padding:2rem}.details-header{align-items:center;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;margin-bottom:1.5rem;padding-bottom:1rem}.details-header h4{color:var(--text-primary);font-size:1.5rem;font-weight:700}.price-section{margin-bottom:2rem}.current-price{color:var(--text-primary);font-size:2.5rem;margin-bottom:.5rem}.price-change{font-size:1.2rem;font-weight:600;gap:.5rem}.price-change.positive{color:var(--success-color)}.price-change.negative{color:var(--error-color)}.details-grid{grid-gap:1rem;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:1.5rem}.detail-item{gap:.25rem}.detail-item .label{color:var(--text-secondary);font-size:.9rem;font-weight:500}.detail-item .value{color:var(--text-primary);font-size:1.1rem;font-weight:600}.last-updated{border-top:1px solid var(--border-color);font-size:.9rem;padding-top:1rem;text-align:center}.last-updated,.no-results{color:var(--text-secondary)}.no-results{padding:3rem}.no-results p:first-child{font-size:1.2rem;font-weight:600;margin-bottom:.5rem}@media (max-width:768px){.search-stocks{padding:1rem}.search-header h2{font-size:1.5rem}.details-grid,.results-grid{grid-template-columns:1fr}.current-price{font-size:2rem}.details-header{align-items:flex-start;flex-direction:column;gap:.5rem}}.loading-spinner-container{align-items:center;display:flex;justify-content:center;min-height:200px;padding:2rem}.loading-spinner-wrapper{align-items:center;display:flex;flex-direction:column;gap:1rem;text-align:center}.loading-spinner{animation:spin 1s linear infinite;color:var(--info-color)}.loading-spinner-small{height:24px;width:24px}.loading-spinner-medium{height:48px;width:48px}.loading-spinner-large{height:64px;width:64px}.loading-content{align-items:center;display:flex;flex-direction:column;gap:.5rem;max-width:400px}.loading-message{color:var(--text-primary);font-size:1rem;font-weight:500;margin:0}.loading-submessage{color:var(--text-secondary);font-size:.875rem;margin:0}.loading-progress{display:flex;flex-direction:column;gap:.5rem;margin-top:.5rem;width:100%}.loading-progress-bar{background:var(--bg-tertiary);border-radius:4px;height:8px;overflow:hidden;width:100%}.loading-progress-fill{animation:pulse 1.5s ease-in-out infinite;background:var(--gradient-primary);border-radius:4px;height:100%;transition:width .3s ease}.loading-progress-text{color:var(--text-secondary);font-size:.75rem;text-align:center}.loading-details{display:flex;flex-direction:column;gap:.5rem;margin-top:1rem;text-align:left;width:100%}.loading-detail-item{align-items:center;color:var(--text-secondary);display:flex;font-size:.875rem;gap:.5rem}.loading-detail-icon{color:var(--info-color);font-weight:700}.loading-detail-text{flex:1 1}.loading-inline{align-items:center;display:inline-flex;gap:.5rem}.loading-inline .loading-spinner{height:16px;width:16px}.loading-skeleton,.skeleton{animation:skeleton-loading 1.5s ease-in-out infinite;background:linear-gradient(90deg,var(--skeleton-bg) 25%,var(--skeleton-shine) 50%,var(--skeleton-bg) 75%);background-size:200% 100%;border-radius:4px}.skeleton{display:inline-block}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-text{margin:.25rem 0}.skeleton-card{background:var(--card-bg);border-radius:8px;box-shadow:0 2px 4px var(--card-shadow);margin-bottom:1rem;padding:1rem}.skeleton-card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.skeleton-card-body{margin-bottom:1rem}.skeleton-card-body .skeleton-text{margin-bottom:.5rem}.skeleton-card-footer{display:flex;gap:1rem;justify-content:space-between}.skeleton-table-container{overflow-x:auto;width:100%}.skeleton-table{border-collapse:collapse;width:100%}.skeleton-table thead th{border-bottom:2px solid #e0e0e0;border-bottom:2px solid var(--border-color,#e0e0e0);padding:.75rem;text-align:left}.skeleton-table tbody td{border-bottom:1px solid #f0f0f0;border-bottom:1px solid var(--border-color,#f0f0f0);padding:.75rem}.skeleton-table-row{animation:skeleton-fade-in .3s ease-in}@keyframes skeleton-fade-in{0%{opacity:0}to{opacity:1}}.skeleton-stock-card{background:var(--card-bg);border-radius:8px;box-shadow:0 1px 3px var(--card-shadow);margin-bottom:.75rem;padding:1rem;transition:transform .2s ease}.skeleton-stock-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.75rem}.skeleton-stock-price{margin-bottom:.75rem}.skeleton-stock-price .skeleton-text:first-child{height:2rem;margin-bottom:.5rem}.skeleton-stock-footer{display:flex;gap:.5rem;justify-content:space-between}.skeleton-stock-list{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));margin-top:1rem}@media (max-width:768px){.skeleton-stock-list{grid-template-columns:1fr}}.skeleton-market-overview{background:var(--card-bg);border-radius:12px;box-shadow:0 2px 8px var(--card-shadow);margin-bottom:2rem;padding:1.5rem}.skeleton-market-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.5rem}.skeleton-market-indices{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.skeleton-index-card{background:var(--bg-secondary);border-radius:8px;display:flex;flex-direction:column;gap:.5rem;padding:1rem}.skeleton-index-card .skeleton-text:first-child{height:1.2rem}.skeleton-index-card .skeleton-text:nth-child(2){height:1.8rem}.skeleton-index-card .skeleton-text:last-child{height:1rem}.skeleton-chart{background:var(--card-bg);border-radius:8px;box-shadow:0 2px 4px var(--card-shadow);padding:1rem}.skeleton-chart-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.skeleton-chart-body{align-items:flex-end;display:flex;gap:2px;height:calc(100% - 60px);justify-content:space-between;padding:1rem 0}.skeleton-chart-bar{animation:skeleton-bar-pulse 1.5s ease-in-out infinite;background:linear-gradient(180deg,var(--primary-color) 0,var(--primary-hover) 100%);border-radius:2px 2px 0 0;flex:1 1;min-height:20px;opacity:.3}@keyframes skeleton-bar-pulse{0%,to{opacity:.6}50%{opacity:1}}[data-theme=dark] .skeleton-card,[data-theme=dark] .skeleton-chart,[data-theme=dark] .skeleton-market-overview,[data-theme=dark] .skeleton-stock-card{background:var(--card-bg);box-shadow:0 2px 8px var(--card-shadow)}[data-theme=dark] .skeleton-index-card{background:var(--bg-secondary)}[data-theme=dark] .skeleton-table thead th{border-bottom-color:var(--border-color)}[data-theme=dark] .skeleton-table tbody td{border-bottom-color:var(--border-color-light)}.skeleton-portfolio-card{background:var(--card-bg);border-radius:12px;box-shadow:0 2px 8px var(--card-shadow);margin-bottom:1rem;padding:1.5rem}.skeleton-portfolio-header{align-items:center;border-bottom:1px solid #e0e0e0;border-bottom:1px solid var(--border-color,#e0e0e0);display:flex;justify-content:space-between;margin-bottom:1rem;padding-bottom:1rem}.skeleton-portfolio-body{margin-bottom:1rem}.skeleton-portfolio-body .skeleton-text{margin-bottom:.75rem}.skeleton-portfolio-footer{border-top:1px solid #e0e0e0;border-top:1px solid var(--border-color,#e0e0e0);display:flex;gap:1rem;justify-content:space-between;padding-top:1rem}.skeleton-portfolio-list{display:flex;flex-direction:column;gap:1rem}.skeleton-news-card{background:var(--card-bg);border-radius:12px;box-shadow:0 2px 8px var(--card-shadow);margin-bottom:1.5rem;overflow:hidden}.skeleton-news-image{background:var(--bg-secondary);height:200px;width:100%}.skeleton-news-content{padding:1.5rem}.skeleton-news-content .skeleton-text{margin-bottom:.75rem}.skeleton-news-content .skeleton-text:first-child{margin-bottom:.5rem}.skeleton-news-list{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}@media (max-width:768px){.skeleton-news-list{grid-template-columns:1fr}}.skeleton-profile-form{background:var(--card-bg);border-radius:12px;box-shadow:0 2px 8px var(--card-shadow);padding:2rem}.skeleton-profile-header{border-bottom:1px solid #e0e0e0;border-bottom:1px solid var(--border-color,#e0e0e0);display:flex;gap:2rem;margin-bottom:2rem;padding-bottom:2rem}.skeleton-avatar{border-radius:50%;flex-shrink:0}.skeleton-profile-info{display:flex;flex:1 1;flex-direction:column;gap:.5rem}.skeleton-profile-fields{display:flex;flex-direction:column;gap:1.5rem}.skeleton-field{display:flex;flex-direction:column;gap:.5rem}.skeleton-admin-dashboard{padding:2rem}.skeleton-admin-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:2rem}.skeleton-admin-stats{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:2rem}.skeleton-stat-card{border-radius:12px;box-shadow:0 2px 8px var(--card-shadow);gap:.75rem}.skeleton-stat-card .skeleton-text:first-child{height:1rem}.skeleton-stat-card .skeleton-text:nth-child(2){height:2rem}.skeleton-stat-card .skeleton-text:last-child{height:.9rem}[data-theme=dark] .skeleton-news-card,[data-theme=dark] .skeleton-portfolio-card,[data-theme=dark] .skeleton-profile-form,[data-theme=dark] .skeleton-stat-card{background:var(--card-bg)}[data-theme=dark] .skeleton-portfolio-footer,[data-theme=dark] .skeleton-portfolio-header,[data-theme=dark] .skeleton-profile-header{border-color:var(--border-color)}[data-theme=dark] .skeleton-news-image{background:var(--bg-secondary)}.error-boundary-content{box-shadow:0 20px 60px var(--card-shadow-hover)}.error-button.primary:hover{box-shadow:0 10px 20px var(--card-shadow-hover)}.error-button.secondary:hover{background:var(--bg-tertiary)}.error-details pre{background:var(--bg-primary-dark)}.loading-container{background:var(--gradient-primary);min-height:100vh}.loading-spinner{color:var(--text-inverse);flex-direction:column;gap:16px}.loading-spinner p{font-size:16px;font-weight:500;margin:0}.language-switcher-button{background:var(--card-bg);border:1px solid var(--border-color);color:var(--text-secondary)}.language-switcher-button:hover{background:var(--bg-secondary);border-color:var(--primary-color);color:var(--primary-color)}.language-dropdown{background:var(--card-bg);border:1px solid var(--border-color);box-shadow:0 4px 12px var(--card-shadow-lg)}.language-option{color:var(--text-primary)}.language-option:hover{background:var(--bg-secondary)}.language-option.active{background:var(--info-light)}.language-check{color:var(--info-color)}.clock-container{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:var(--info-light);border:1px solid var(--border-color);border-radius:12px;box-shadow:0 4px 6px -1px var(--card-shadow),0 2px 4px -1px var(--card-shadow);color:var(--text-primary);display:flex;font-size:14px;gap:10px;min-width:140px;padding:10px 16px;transition:all .3s ease}.clock-container:hover{background:var(--info-light);border-color:var(--info-color);box-shadow:0 10px 15px -3px var(--card-shadow-hover),0 4px 6px -2px var(--card-shadow);opacity:.9;transform:translateY(-1px)}.clock-icon{color:var(--info-color);flex-shrink:0;opacity:.9}.clock-content{display:flex;flex:1 1;flex-direction:column;gap:3px}.clock-time{color:var(--text-inverse);font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,Courier New,monospace;font-size:15px;font-weight:700;letter-spacing:1px;line-height:1.2;text-shadow:0 1px 2px var(--text-shadow-dark)}.clock-timezone{font-size:10px;font-weight:500;letter-spacing:.5px;opacity:.75;text-transform:uppercase}.clock-syncing{align-items:center;display:flex;font-size:10px;font-weight:500;gap:5px;opacity:.7}.sync-indicator{animation:pulse 1.5s ease-in-out infinite;color:var(--success-color);font-size:8px}.navbar-clock{margin-right:8px}@media (max-width:768px){.clock-container{font-size:13px;min-width:120px;padding:8px 12px}.clock-time{font-size:14px}.clock-timezone{font-size:9px}}.modal-overlay{animation:fadeIn .2s ease-in-out}.modal-container{animation:slideUp .3s ease-out;background:var(--card-bg);border:1px solid var(--card-border);border-radius:12px;box-shadow:0 20px 60px var(--card-shadow-hover);display:flex;flex-direction:column;max-height:90vh;overflow:hidden;position:relative}.modal-container.modal-small{max-width:400px;width:90%}.modal-container.modal-medium{max-width:600px;width:90%}.modal-container.modal-large{max-width:900px;width:90%}.modal-header-content{align-items:center;display:flex;gap:.75rem}.modal-icon{flex-shrink:0;height:24px;width:24px}.modal-icon-info{color:var(--info-color)}.modal-icon-success{color:var(--success-color)}.modal-icon-warning{color:var(--warning-color)}.modal-icon-error{color:var(--error-color)}.modal-title{color:var(--text-primary);font-size:1.25rem;font-weight:600;margin:0}.modal-close-button{align-items:center;background:none;border:none;border-radius:6px;color:var(--text-secondary);cursor:pointer;display:flex;justify-content:center;padding:.5rem;transition:all .2s}.modal-close-button:hover{background:var(--bg-secondary);color:var(--text-primary)}.modal-body{color:var(--text-primary);line-height:1.6;max-height:calc(90vh - 100px)}.modal-container.modal-info{border-top:4px solid var(--info-color)}.modal-container.modal-success{border-top:4px solid var(--success-color)}.modal-container.modal-warning{border-top:4px solid var(--warning-color)}.modal-container.modal-error{border-top:4px solid var(--error-color)}@media (max-width:640px){.modal-container{max-height:95vh;width:95%}.modal-body,.modal-header{padding:1rem}}.welcome-modal-overlay{align-items:center;animation:fadeIn .3s ease;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#000000bf;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:10000}.welcome-modal-content{animation:slideUp .4s ease;background:var(--card-bg);border:1px solid var(--card-border);border-radius:24px;box-shadow:0 20px 60px #0000004d;max-height:90vh;max-width:900px;overflow-y:auto;position:relative;width:100%}.welcome-modal-close{align-items:center;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:50%;color:var(--text-secondary);cursor:pointer;display:flex;height:40px;justify-content:center;position:absolute;right:1.5rem;top:1.5rem;transition:all .2s ease;width:40px;z-index:10}.welcome-modal-close:hover{background:var(--error-color);border-color:var(--error-color);color:#fff;transform:rotate(90deg)}.welcome-modal-header{background:linear-gradient(135deg,var(--primary-color) 0,var(--primary-hover) 100%);border-radius:24px 24px 0 0;overflow:hidden;padding:3rem 2rem 2rem;position:relative;text-align:center}.welcome-modal-header:before{background:url("data:image/svg+xml;charset=utf-8,%3Csvg width='100' height='100' xmlns='http://www.w3.org/2000/svg'%3E%3Cdefs%3E%3Cpattern id='a' width='20' height='20' patternUnits='userSpaceOnUse'%3E%3Cpath d='M20 0H0v20' fill='none' stroke='rgba(255,255,255,0.1)'/%3E%3C/pattern%3E%3C/defs%3E%3Cpath fill='url(%23a)' d='M0 0h100v100H0z'/%3E%3C/svg%3E");bottom:0;content:"";left:0;opacity:.3;position:absolute;right:0;top:0}.welcome-icon-wrapper{display:inline-flex;margin-bottom:1rem;position:relative;z-index:1}.welcome-sparkle{animation:sparkle 2s ease-in-out infinite;color:#fff}@keyframes sparkle{0%,to{opacity:1;transform:scale(1) rotate(0deg)}50%{opacity:.8;transform:scale(1.1) rotate(180deg)}}.welcome-title{color:#fff;font-size:2.5rem;font-weight:900;margin:0 0 .5rem;position:relative;text-shadow:0 2px 10px #0003;z-index:1}.welcome-subtitle{color:#fffffff2;font-size:1.125rem;font-weight:500;margin:0;position:relative;z-index:1}.welcome-modal-body{padding:2.5rem}.welcome-intro{color:var(--text-secondary);font-size:1.0625rem;line-height:1.7;margin:0 0 2.5rem;padding:0 1rem;text-align:center}.welcome-features-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:2.5rem}.welcome-feature-card{animation:fadeInUp .6s ease backwards;background:var(--bg-secondary);border:1px solid var(--card-border);border-radius:16px;padding:1.5rem;text-align:center;transition:all .3s ease}.welcome-feature-card:hover{border-color:var(--primary-color);box-shadow:0 8px 24px var(--card-shadow-hover);transform:translateY(-4px)}.welcome-feature-icon{align-items:center;border-radius:16px;display:flex;height:64px;justify-content:center;margin:0 auto 1rem;transition:transform .3s ease;width:64px}.welcome-feature-card:hover .welcome-feature-icon{transform:scale(1.1) rotate(5deg)}.welcome-feature-title{color:var(--text-primary);font-size:1.0625rem;font-weight:700;margin:0 0 .5rem}.welcome-feature-description{color:var(--text-secondary);font-size:.875rem;line-height:1.5;margin:0}.welcome-highlights{background:var(--info-light);border:1px solid var(--info-color);border-radius:12px;display:flex;flex-direction:column;gap:1rem;margin-bottom:1rem;padding:1.5rem}.welcome-highlight-item{align-items:center;color:var(--text-primary);display:flex;font-size:.9375rem;font-weight:500;gap:.75rem}.highlight-icon{color:var(--info-color);flex-shrink:0}.welcome-modal-footer{background:var(--bg-secondary);border-radius:0 0 24px 24px;border-top:1px solid var(--border-color);padding:2rem 2.5rem;text-align:center}.welcome-cta-button{align-items:center;background:var(--primary-color);border:none;border-radius:12px;box-shadow:0 4px 12px var(--primary-shadow-md);color:#fff;cursor:pointer;display:inline-flex;font-size:1.0625rem;font-weight:600;gap:.75rem;margin-bottom:.75rem;padding:1rem 2.5rem;text-decoration:none;transition:all .3s ease}.welcome-cta-button:hover{background:var(--primary-hover);box-shadow:0 8px 24px var(--primary-shadow-hover);color:#fff;transform:translateY(-2px)}.welcome-cta-button:active{transform:translateY(0)}.welcome-btn-secondary{color:var(--text-secondary);display:inline-block;font-size:.9375rem;font-weight:500;margin-bottom:1rem;padding:.75rem 1.5rem;text-decoration:none;transition:all .2s ease}.welcome-btn-secondary:hover{color:var(--primary-color)}.welcome-footer-note{color:var(--text-secondary);font-size:.875rem;margin:0}@media (max-width:768px){.welcome-modal-content{border-radius:20px;max-height:95vh;max-width:100%}.welcome-modal-header{border-radius:20px 20px 0 0;padding:2.5rem 1.5rem 1.5rem}.welcome-title{font-size:2rem}.welcome-subtitle{font-size:1rem}.welcome-modal-body{padding:2rem 1.5rem}.welcome-features-grid{gap:1.25rem;grid-template-columns:1fr}.welcome-modal-footer{padding:1.5rem}.welcome-cta-button{justify-content:center;padding:.875rem 2rem;width:100%}}@media (max-width:480px){.welcome-modal-overlay{padding:.5rem}.welcome-modal-header{padding:2rem 1rem 1.25rem}.welcome-title{font-size:1.75rem}.welcome-modal-body{padding:1.5rem 1rem}.welcome-feature-card,.welcome-highlights{padding:1.25rem}}.welcome-modal-content::-webkit-scrollbar{width:8px}.welcome-modal-content::-webkit-scrollbar-track{background:var(--bg-secondary);border-radius:4px}.welcome-modal-content::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}.welcome-modal-content::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}.home-modern{background:var(--bg-primary);min-height:100vh}.hero-section{align-items:center;display:flex;min-height:90vh;overflow:hidden;padding-top:80px;position:relative}.hero-background{z-index:0}.hero-background,.hero-gradient{bottom:0;left:0;position:absolute;right:0;top:0}.hero-gradient{background:radial-gradient(ellipse at top,#3b82f626 0,#0000 50%),radial-gradient(ellipse at bottom right,#9333ea1a 0,#0000 50%)}.hero-pattern{animation:patternMove 20s linear infinite;background-image:linear-gradient(#3b82f608 1px,#0000 0),linear-gradient(90deg,#3b82f608 1px,#0000 0);background-size:50px 50px;bottom:0;left:0;position:absolute;right:0;top:0}@keyframes patternMove{0%{transform:translate(0)}to{transform:translate(50px,50px)}}.hero-content{margin:0 auto;max-width:900px;padding:2rem 0;position:relative;text-align:center;z-index:1}.hero-badge{align-items:center;background:#3b82f61a;border:1px solid #3b82f633;border-radius:50px;color:var(--primary-color);display:inline-flex;font-size:.875rem;font-weight:600;gap:.5rem;margin-bottom:2rem;padding:.5rem 1rem}.hero-title{color:var(--text-primary);font-size:4rem;font-weight:900;line-height:1.1;margin-bottom:1.5rem}.hero-subtitle{color:var(--text-secondary);font-size:1.25rem;line-height:1.6;margin-bottom:2.5rem;margin-left:auto;margin-right:auto;max-width:700px}.hero-cta{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;margin-bottom:3rem}.btn-large{font-size:1.05rem;padding:1rem 2rem}.hero-stats{border-top:1px solid var(--border-color);display:flex;flex-wrap:wrap;gap:3rem;justify-content:center;padding-top:2rem}.stat-item{gap:1rem}.stat-info{text-align:left}.stat-info .stat-value{color:var(--text-primary);font-size:1.5rem;font-weight:700}.stat-info .stat-label{color:var(--text-secondary);font-size:.875rem}.ticker-section{background:var(--card-bg);border-bottom:1px solid var(--border-color);border-top:1px solid var(--border-color);overflow:hidden;padding:1rem 0}.ticker-tape{overflow:hidden;width:100%}.ticker-track{animation:tickerScroll 60s linear infinite;display:flex;gap:3rem;white-space:nowrap}@keyframes tickerScroll{0%{transform:translateX(0)}to{transform:translateX(-33.333%)}}.ticker-item{align-items:center;background:var(--bg-secondary);border-radius:8px;display:inline-flex;gap:.75rem;padding:.5rem 1rem}.ticker-symbol{color:var(--text-primary);font-weight:700}.ticker-price{color:var(--text-secondary);font-size:.95rem}.ticker-change{font-size:.875rem;font-weight:600}.ticker-change.positive{color:var(--success-color)}.ticker-change.negative{color:var(--error-color)}.section-header{margin-bottom:2rem}.section-header.text-center{flex-direction:column;text-align:center}.section-title{font-size:2.5rem;font-weight:800}.section-subtitle{color:var(--text-secondary);font-size:1.125rem;margin-top:.5rem;max-width:600px}.section-link{align-items:center;color:var(--primary-color);display:flex;font-weight:600;gap:.5rem;text-decoration:none;transition:gap .3s}.section-link:hover{gap:.75rem}.market-overview-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.market-index-card{padding:2rem;transition:all .3s}.market-index-card:hover{transform:translateY(-8px)}.index-header{gap:1rem;margin-bottom:1.5rem}.index-icon{align-items:center;border-radius:16px;color:#fff;display:flex;height:56px;justify-content:center;width:56px}.index-icon.ihsg{background:linear-gradient(135deg,#667eea,#764ba2)}.index-icon.lq45{background:linear-gradient(135deg,#f093fb,#f5576c)}.index-icon.idx30{background:linear-gradient(135deg,#4facfe,#00f2fe)}.index-info{flex:1 1}.index-name{font-size:1.25rem;font-weight:700}.index-desc{color:var(--text-secondary);font-size:.875rem}.index-value{color:var(--text-primary);font-size:2.5rem;font-weight:800;margin-bottom:.75rem}.index-change{font-size:1.125rem;gap:.5rem}.change-value{font-size:.875rem;opacity:.8}.features-grid{grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}.feature-card{cursor:pointer;display:flex;flex-direction:column;position:relative;text-decoration:none}.feature-card:after{background:var(--gradient);border-radius:20px 20px 0 0;content:"";height:4px;left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .3s}.feature-card:hover:after{opacity:1}.feature-icon{border-radius:16px;box-shadow:0 8px 24px #00000026;margin-bottom:1.5rem}.feature-title{color:var(--text-primary);font-size:1.25rem;font-weight:700;margin-bottom:.75rem}.feature-description{color:var(--text-secondary);flex:1 1;font-size:.95rem;line-height:1.6;margin-bottom:1rem}.feature-arrow{color:var(--primary-color);opacity:0;transform:translateX(-10px);transition:all .3s}.feature-card:hover .feature-arrow{opacity:1;transform:translateX(0)}.cta-section{padding:4rem 0}.cta-card{background:linear-gradient(135deg,#3b82f61a,#9333ea1a);padding:4rem 3rem;text-align:center}.cta-title{color:var(--text-primary);font-size:2.5rem;font-weight:800;margin-bottom:1rem}.cta-subtitle{color:var(--text-secondary);font-size:1.125rem;margin-bottom:2rem;margin-left:auto;margin-right:auto;max-width:600px}.cta-buttons{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}@media (max-width:1024px){.hero-title{font-size:3rem}.section-title{font-size:2rem}}@media (max-width:768px){.hero-title{font-size:2.5rem}.hero-subtitle{font-size:1.05rem}.hero-stats{gap:1.5rem}.features-grid,.market-overview-grid{grid-template-columns:1fr}.cta-card{padding:3rem 2rem}.cta-title{font-size:2rem}}.portax-info-section{padding:3rem 0}.section-title .section-icon{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;box-shadow:0 4px 12px #667eea4d;color:#fff;display:inline-flex;height:48px;justify-content:center;margin-right:.75rem;min-height:48px;min-width:48px;vertical-align:middle;width:48px}.portax-info-carousel{overflow:hidden;position:relative}.carousel-container{border-radius:16px;overflow:hidden}.carousel-track{display:flex;transition:transform .5s ease}.info-card{background:var(--bg-card);border-radius:16px;display:block;flex:0 0 100%;min-width:100%;overflow:hidden;text-decoration:none;transition:all .3s ease}.info-card:hover{box-shadow:0 8px 32px var(--shadow-color);transform:scale(1.02)}.info-image{height:200px;overflow:hidden;position:relative;width:100%}.info-image img{height:100%;object-fit:cover;width:100%}.info-badge{border-radius:20px;color:#fff;font-size:.75rem;font-weight:600;left:1rem;padding:.35rem .75rem;position:absolute;text-transform:uppercase;top:1rem}.info-content{padding:1.5rem}.info-content h3{color:var(--text-primary);font-size:1.25rem;font-weight:700;margin-bottom:.5rem}.info-content p{color:var(--text-secondary);font-size:.95rem;line-height:1.5;margin:0}.carousel-btn{align-items:center;background:var(--bg-card);border:1px solid var(--border-color);border-radius:50%;box-shadow:0 4px 12px var(--shadow-color);color:var(--text-primary);cursor:pointer;display:flex;height:40px;justify-content:center;position:absolute;top:50%;transform:translateY(-50%);transition:all .3s ease;width:40px;z-index:10}.carousel-btn:hover{background:var(--primary-color);border-color:var(--primary-color);color:#fff}.carousel-btn.prev{left:1rem}.carousel-btn.next{right:1rem}.carousel-dots{display:flex;gap:.5rem;justify-content:center;margin-top:1rem}.carousel-dots .dot{background:var(--border-color);border:none;border-radius:50%;cursor:pointer;height:8px;padding:0;transition:all .3s ease;width:8px}.carousel-dots .dot.active{background:var(--primary-color);border-radius:4px;width:24px}@media (min-width:768px){.carousel-track{gap:1.5rem}.info-card{flex-basis:calc(33.333% - 1rem);flex-grow:0;flex-shrink:0;min-width:calc(33.333% - 1rem)}.carousel-container{overflow:visible}.carousel-btn.prev{left:-1rem}.carousel-btn.next{right:-1rem}}.changelog-section{background:var(--bg-secondary);padding:4rem 0}.changelog-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.changelog-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;cursor:pointer;padding:1.5rem;transition:all .3s ease}.changelog-card:hover{border-color:var(--primary-color);box-shadow:0 8px 24px var(--shadow-color);transform:translateY(-4px)}.changelog-header{justify-content:space-between;margin-bottom:1rem}.changelog-type{gap:.35rem;padding:.3rem .6rem}.changelog-type.large{font-size:.85rem;padding:.5rem 1rem}.changelog-version{background:#3b82f61a;border-radius:20px;font-size:.875rem;padding:.25rem .75rem}.changelog-title{font-size:1.1rem;font-weight:700}.changelog-date{color:var(--text-secondary);font-size:.85rem;margin-bottom:1rem}.changelog-highlights li{font-size:.9rem;margin-bottom:.35rem}.changelog-modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000}.changelog-modal{background:var(--bg-card);border:1px solid var(--border-color);border-radius:20px;box-shadow:0 20px 60px #0000004d;display:flex;flex-direction:column;max-height:80vh;max-width:600px;overflow:hidden;width:100%}.changelog-modal-header{align-items:center;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:1.5rem}.changelog-modal-header h2{align-items:center;color:var(--text-primary);display:flex;font-size:1.25rem;font-weight:700;gap:.75rem;margin:0}.changelog-modal-header button{background:#0000;border:none;border-radius:8px;color:var(--text-secondary);cursor:pointer;padding:.5rem;transition:all .2s}.changelog-modal-header button:hover{background:var(--bg-secondary);color:var(--text-primary)}.changelog-modal-content{flex:1 1;overflow-y:auto;padding:1.5rem}.changelog-list{display:flex;flex-direction:column;gap:.75rem}.changelog-list-item{align-items:center;background:var(--bg-secondary);border:1px solid #0000;border-radius:12px;cursor:pointer;display:flex;justify-content:space-between;padding:1rem;transition:all .2s}.changelog-list-item:hover{background:var(--bg-tertiary);border-color:var(--primary-color)}.list-item-left{align-items:center;display:flex;gap:1rem}.list-item-left h4{color:var(--text-primary);font-size:.95rem;font-weight:600;margin:0}.list-item-left p{color:var(--text-secondary);font-size:.85rem;margin:.25rem 0 0}.changelog-detail{display:flex;flex-direction:column;gap:1rem}.detail-header{align-items:center;display:flex;justify-content:space-between}.changelog-detail h3{color:var(--text-primary);font-size:1.5rem;font-weight:700;margin:0}.detail-list{list-style:none;margin:1rem 0;padding:0}.detail-list li{align-items:flex-start;background:var(--bg-secondary);border-radius:8px;color:var(--text-primary);display:flex;font-size:.95rem;gap:.75rem;margin-bottom:.5rem;padding:.75rem}.detail-list li svg{color:var(--primary-color);flex-shrink:0;margin-top:2px}.back-btn{align-items:center;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-secondary);cursor:pointer;display:inline-flex;font-size:.9rem;font-weight:500;gap:.5rem;margin-top:1rem;padding:.75rem 1rem;transition:all .2s}.back-btn:hover{background:var(--primary-color);border-color:var(--primary-color);color:#fff}@media (max-width:768px){.portax-info-section{padding:2rem 0}.info-image{height:150px}.carousel-btn{height:32px;width:32px}.carousel-btn.prev{left:.5rem}.carousel-btn.next{right:.5rem}.changelog-section{padding:2rem 0}.changelog-grid{grid-template-columns:1fr}.changelog-modal{border-radius:16px;max-height:90vh}}.universe-animation-container{background:linear-gradient(180deg,#0a0e27 0,#1a1d29);border-radius:16px;height:400px;overflow:hidden;position:relative;width:100%}.universe-canvas{display:block;height:100%;width:100%}.universe-overlay{color:#fff;left:50%;pointer-events:none;position:absolute;text-align:center;top:50%;transform:translate(-50%,-50%);z-index:10}.universe-overlay h3{font-size:2rem;font-weight:700;margin:0 0 .5rem;text-shadow:0 2px 10px #00000080}.universe-overlay p{font-size:1rem;margin:0;opacity:.9;text-shadow:0 1px 5px #00000080}.market-overview{background:#0000;border:none;border-radius:0;box-shadow:none;box-sizing:border-box;margin-bottom:0;padding:0;width:100%}.market-overview-header{align-items:center;border-bottom:2px solid var(--border-color-light);display:flex;gap:12px;margin-bottom:20px;padding-bottom:16px}.market-overview-header h2{color:var(--text-primary);font-size:1.5rem;font-weight:600;margin:0}.market-overview-content{display:flex;flex-direction:column;gap:24px}.exchange-group{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;display:flex;flex-direction:column;gap:20px;margin-bottom:24px;padding:20px}.exchange-name{border-bottom:2px solid var(--primary-color);color:var(--text-primary);font-size:1.25rem;font-weight:700;margin:0 0 16px;padding-bottom:12px}.type-group{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}.type-name{border-left:3px solid var(--primary-color);color:var(--text-secondary);font-size:1rem;font-weight:600;margin:0 0 8px;padding-left:8px}.indices-slider-container{padding:0 3rem}.indices-slider-container,.indices-slider-wrapper{overflow:hidden;position:relative;width:100%}.indices-slider{display:flex;gap:1.5rem;width:100%;will-change:transform}.slider-nav-btn{align-items:center;background:var(--card-bg);border:2px solid var(--border-color);border-radius:50%;box-shadow:0 4px 12px var(--card-shadow);color:var(--text-primary);cursor:pointer;display:flex;height:48px;justify-content:center;position:absolute;top:50%;transform:translateY(-50%);transition:all .3s ease;width:48px;z-index:10}.slider-nav-btn:hover:not(:disabled){background:var(--primary-color);border-color:var(--primary-color);box-shadow:0 6px 20px var(--primary-shadow-hover);color:#fff;transform:translateY(-50%) scale(1.1)}.slider-nav-btn:disabled{cursor:not-allowed;opacity:.3}.slider-nav-prev{left:.5rem}.slider-nav-next{right:.5rem}.index-card-slider{background:var(--card-bg);border:2px solid var(--card-border);border-radius:16px;box-shadow:0 2px 8px var(--card-shadow);cursor:pointer;display:flex;flex-direction:column;gap:1rem;min-width:0;padding:1.5rem;transition:all .3s ease}.index-card-slider:hover{border-color:var(--primary-color);box-shadow:0 8px 24px var(--card-shadow-hover);transform:translateY(-4px)}.index-card-header{justify-content:space-between;margin-bottom:.5rem}.index-card-badge,.index-card-header{align-items:center;display:flex}.index-exchange-badge{background:var(--primary-light);border-radius:12px;color:var(--primary-color);font-size:.75rem;font-weight:600;letter-spacing:.5px;padding:.25rem .75rem;text-transform:uppercase}.index-ticker-slider{background:var(--bg-tertiary);border-radius:6px;color:var(--text-secondary);font-size:.75rem;font-weight:500;padding:.25rem .5rem}.index-card-body{display:flex;flex-direction:column;gap:.75rem}.index-name-slider{color:var(--text-primary);font-size:1rem;font-weight:700;line-height:1.3;margin:0}.index-price-slider{color:var(--text-primary);font-size:1.75rem;font-weight:800;line-height:1.2}.index-change-slider{align-items:center;border-radius:8px;display:flex;font-weight:600;gap:.5rem;padding:.5rem}.index-change-slider.positive{background:var(--success-light);color:var(--success-color)}.index-change-slider.negative{background:var(--error-light);color:var(--error-color)}.index-change-details{display:flex;flex-direction:column;gap:.25rem}.index-change-percent{font-size:1rem;font-weight:700}.index-change-amount{font-size:.875rem;font-weight:500;opacity:.8}.index-volume-slider{align-items:center;border-top:1px solid var(--border-color);display:flex;font-size:.875rem;justify-content:space-between;padding-top:.5rem}.volume-label{color:var(--text-secondary);font-weight:500}.volume-value{color:var(--text-primary);font-weight:600}.indices-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.index-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;cursor:pointer;padding:16px;transition:all .2s ease}.index-card:hover{background:var(--card-bg);border-color:var(--primary-color);box-shadow:0 4px 12px var(--card-shadow);transform:translateY(-2px)}.index-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.index-name{color:var(--text-primary);font-size:.95rem;font-weight:600}.index-ticker{background:var(--bg-tertiary);border-radius:4px;color:var(--text-secondary);font-size:.75rem;padding:2px 6px}.index-price{color:var(--text-primary);font-size:1.5rem;font-weight:700;margin-bottom:8px}.index-change{align-items:center;display:flex;font-size:.9rem;font-weight:600;gap:6px;margin-bottom:8px}.index-change.positive{color:var(--success-color)}.index-change.negative{color:var(--error-color)}.change-amount{font-size:.85rem;font-weight:400;opacity:.8}.index-volume{font-size:.75rem;margin-top:4px}.index-volume,.no-indices{color:var(--text-secondary)}.no-indices{padding:40px 20px;text-align:center}@media (max-width:1200px){.indices-slider-container{padding:0 2.5rem}}@media (max-width:768px){.indices-slider-container{padding:0 2rem}.slider-nav-btn{height:40px;width:40px}.slider-nav-prev{left:.25rem}.slider-nav-next{right:.25rem}.index-card-slider{padding:1.25rem}.index-price-slider{font-size:1.5rem}.indices-grid{gap:12px;grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}.index-card{padding:12px}.index-price{font-size:1.2rem}}@media (max-width:480px){.indices-slider-container{padding:0 2.5rem}.slider-nav-btn{height:36px;width:36px}.slider-nav-prev{left:.25rem}.slider-nav-next{right:.25rem}.index-card-slider{padding:1rem}.index-price-slider{font-size:1.25rem}.index-name-slider{font-size:.9rem}}.market-header-modern{background:var(--card-bg);border:1px solid var(--card-border);border-radius:24px;box-shadow:0 8px 32px var(--card-shadow);margin-bottom:2.5rem;overflow:hidden;padding:2.5rem;position:relative}.market-header-modern:before{background:var(--gradient-primary);content:"";height:4px;left:0;position:absolute;right:0;top:0}.market-header-top{align-items:flex-start;display:flex;flex-wrap:wrap;gap:2rem;justify-content:space-between;margin-bottom:2rem}.market-header-title-section{flex:1 1;min-width:300px}.market-icon-wrapper{align-items:center;background:var(--primary-color);border-radius:16px;box-shadow:0 8px 24px var(--primary-shadow-md);color:var(--text-inverse);display:flex;height:64px;justify-content:center;margin-bottom:1rem;width:64px}.market-title-modern{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,var(--text-primary) 0,var(--primary-color) 100%);-webkit-background-clip:text;background-clip:text;font-size:2.5rem;font-weight:900;margin:0 0 .5rem}.market-subtitle-modern{color:var(--text-secondary);font-size:1.05rem;line-height:1.6;margin:0}.market-header-actions{align-items:center;display:flex;gap:1rem}.refresh-btn-modern{align-items:center;background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;box-shadow:0 2px 8px var(--card-shadow);color:var(--text-primary);cursor:pointer;display:flex;font-weight:600;gap:.75rem;padding:.875rem 1.5rem;transition:all .3s}.refresh-btn-modern:hover{background:var(--bg-hover);border-color:var(--primary-color);box-shadow:0 4px 12px var(--card-shadow);color:var(--primary-color);transform:translateY(-2px)}.market-controls{background:var(--card-bg);border:1px solid var(--card-border);border-radius:16px;box-shadow:0 4px 16px var(--card-shadow);margin-bottom:2rem;padding:1.5rem}.search-filter-row{align-items:center;display:flex;flex-wrap:wrap;gap:1rem}.search-box{min-width:280px;position:relative}.search-box input{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;font-size:.95rem;padding:.875rem 1rem .875rem 3rem;transition:all .3s}.search-box input:focus{background:var(--card-bg);border-color:var(--primary-color);box-shadow:0 0 0 3px var(--info-color-alpha-01);outline:none}.search-box svg{left:1rem;position:absolute;top:50%;transform:translateY(-50%)}.filter-item{display:flex;flex-direction:column;gap:.5rem}.filter-item label{align-items:center;color:var(--text-secondary);display:flex;font-size:.875rem;font-weight:600;gap:.5rem}.filter-select{background:var(--bg-secondary);border-radius:10px;font-size:.95rem;transition:all .3s}.filter-select:focus{box-shadow:0 0 0 3px var(--info-color-alpha-01)}.market-overview-section{margin-bottom:3rem}.market-tabs-container{background:var(--card-bg);border:1px solid var(--card-border);border-radius:16px;box-shadow:0 4px 16px var(--card-shadow);display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:2rem;overflow-x:auto;padding:.5rem}.market-tab{background:#0000;border:none;border-radius:12px;color:var(--text-secondary);cursor:pointer;flex:1 1;font-size:.95rem;font-weight:600;min-width:120px;padding:.875rem 1.5rem;position:relative;transition:all .3s}.market-tab:hover{background:var(--bg-hover);color:var(--text-primary)}.market-tab.active{background:var(--gradient-primary);box-shadow:0 4px 12px var(--primary-shadow-md);color:var(--text-inverse)}.market-table-section{background:var(--card-bg);border:1px solid var(--card-border);border-radius:20px;box-shadow:0 8px 32px var(--card-shadow);margin-bottom:2rem;overflow:hidden}.section-header{background:linear-gradient(135deg,var(--info-color-alpha-005) 0,var(--primary-color-alpha-01) 100%);padding:2rem}.section-title{color:var(--text-primary);font-size:1.5rem;font-weight:700;margin:0}.stocks-table-wrapper{overflow-x:auto;width:100%}.stocks-table{min-width:800px;width:100%}.table-header,.table-row{grid-gap:1rem;align-items:center;gap:1rem;grid-template-columns:minmax(250px,3fr) 1fr 1fr 1fr 1fr;padding:1rem 2rem}.table-header{background:var(--bg-secondary);border-bottom:2px solid var(--border-color);color:var(--text-secondary);font-size:.875rem;font-weight:700;letter-spacing:.5px;position:-webkit-sticky;position:sticky;top:0;z-index:10}.table-header>div{align-items:center;display:flex;gap:.5rem}.sortable{cursor:pointer;transition:color .2s;-webkit-user-select:none;user-select:none}.sortable:hover{color:var(--primary-color)}.table-row{border-bottom:1px solid var(--border-color);transition:all .2s}.table-row:hover{background:var(--bg-hover)}.col-symbol,.symbol-info{display:flex;flex-direction:column;gap:.25rem}.symbol{color:var(--text-primary);font-size:1rem;font-weight:700}.company-name-sub{color:var(--text-secondary);font-size:.875rem}.col-price .price{color:var(--text-primary);font-weight:600}.col-change .change{align-items:center;border-radius:8px;display:flex;font-weight:600;gap:.5rem;padding:.375rem .75rem;width:-webkit-fit-content;width:fit-content}.change.positive{background:var(--success-color-alpha-01);color:var(--success-color)}.change.negative{background:var(--error-color-alpha-01);color:var(--error-color)}.col-exchange .exchange,.col-volume .volume{color:var(--text-secondary)}.col-exchange .exchange{background:var(--bg-secondary);border-radius:8px;font-size:.875rem;font-weight:600;padding:.375rem .75rem;width:-webkit-fit-content;width:fit-content}.table-footer{align-items:center;background:var(--bg-secondary);border-top:1px solid var(--border-color);display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;padding:1.5rem 2rem}.pagination-info{font-size:.95rem}.pagination-btn{background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-weight:600}.pagination-btn:hover:not(:disabled){background:var(--bg-hover);border-color:var(--primary-color);color:var(--primary-color)}.pagination-btn.active{background:var(--gradient-primary);border-color:#0000;color:#fff}.error-container,.loading-container,.no-data-message{padding:4rem 2rem;text-align:center}.no-data-message{color:var(--text-secondary)}.no-data-message p:first-child{font-size:1.25rem;font-weight:600;margin-bottom:.5rem}@media (max-width:1024px){.market-title-modern{font-size:2rem}.table-header,.table-row{grid-template-columns:minmax(200px,2fr) 1fr 1fr 1fr 1fr;padding:1rem}}@media (max-width:768px){.market-header-modern{padding:2rem 1.5rem}.market-header-top{flex-direction:column;gap:1.5rem}.market-icon-wrapper{height:56px;width:56px}.market-title-modern{font-size:1.75rem}.market-tabs-container{flex-direction:column}.market-tab{min-width:100%}.search-filter-row{flex-direction:column}.filter-item,.filter-select,.search-box{width:100%}.table-footer{flex-direction:column;text-align:center}}.market-page{background:var(--bg-primary);min-height:100vh}.nav-loading{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.spinning{color:var(--primary-color)}.market-header-section{margin:0 1.5rem}.asset-tabs{background:var(--card-bg);border-bottom:1px solid var(--border-color);display:flex;gap:.5rem;overflow-x:auto;padding:1.25rem 2rem;scrollbar-width:none}.asset-tabs::-webkit-scrollbar{display:none}.asset-tab{align-items:center;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-secondary);cursor:pointer;display:flex;font-size:.875rem;font-weight:600;gap:.5rem;padding:.75rem 1.25rem;transition:all .2s;white-space:nowrap}.asset-tab:hover{background:var(--bg-hover);border-color:var(--primary-color);color:var(--text-primary)}.asset-tab.active{background:var(--primary-color);border-color:var(--primary-color);color:#fff}.tab-icon{font-size:1rem}.tab-label{font-size:.875rem}.market-controls{background:var(--bg-primary);flex-wrap:wrap;gap:1rem;padding:1.25rem 2rem}.market-controls,.search-box{align-items:center;display:flex}.search-box{background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;flex:1 1;gap:.75rem;max-width:400px;min-width:250px;padding:.75rem 1rem}.search-box svg{color:var(--text-tertiary);flex-shrink:0}.search-box input{background:#0000;border:none;color:var(--text-primary);font-size:.9rem;outline:none;width:100%}.search-box input::placeholder{color:var(--text-tertiary)}.filter-select{background:var(--card-bg);border:1px solid var(--border-color);color:var(--text-primary);font-weight:500}.filter-select:focus{border-color:var(--primary-color)}.favorites-btn{align-items:center;background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;color:var(--text-secondary);cursor:pointer;display:flex;font-size:.875rem;font-weight:600;gap:.5rem;padding:.75rem 1rem;transition:all .2s}.favorites-btn:hover{border-color:var(--warning-color);color:var(--warning-color)}.favorites-btn.active{background:var(--warning-color);border-color:var(--warning-color);color:#fff}.market-table-wrapper{overflow-x:auto;padding:0 2rem}.market-table{background:var(--card-bg);border-collapse:collapse;border-radius:12px;box-shadow:0 2px 8px var(--card-shadow);overflow:hidden;width:100%}.market-table thead{background:var(--bg-secondary)}.market-table th{border-bottom:1px solid var(--border-color);color:var(--text-tertiary);font-size:.75rem;font-weight:700;letter-spacing:.5px;padding:1rem;text-align:left;text-transform:uppercase;white-space:nowrap}.market-table th.th-fav{width:40px}.market-table th.th-symbol{min-width:150px}.market-table th.th-price{min-width:120px;text-align:right}.market-table th.th-change,.market-table th.th-volume{min-width:100px;text-align:right}.market-table th.th-mcap{min-width:120px;text-align:right}.market-table th.th-exchange{min-width:80px;text-align:center}.market-table tbody tr{border-bottom:1px solid var(--border-color);cursor:pointer;transition:background .15s}.market-table tbody tr:hover{background:var(--bg-hover)}.market-table tbody tr:last-child{border-bottom:none}.market-table tbody tr.row-favorite{background:#fbbf240d}.market-table tbody tr.row-favorite:hover{background:#fbbf241a}.market-table td{color:var(--text-primary);font-size:.9rem;padding:1rem;vertical-align:middle}.td-fav{text-align:center}.fav-btn{align-items:center;background:none;border:none;color:var(--text-tertiary);cursor:pointer;display:flex;justify-content:center;padding:.25rem;transition:all .2s}.fav-btn:hover{color:var(--warning-color);transform:scale(1.1)}.td-rank{color:var(--text-tertiary);font-size:.85rem;text-align:center}.td-rank,.td-symbol{font-weight:600}.symbol-cell{display:flex;flex-direction:column;gap:.25rem}.symbol-ticker{color:var(--text-primary);font-weight:700}.symbol-name{color:var(--text-tertiary);font-size:.8rem;font-weight:400;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.td-price{font-family:SF Mono,Monaco,Consolas,monospace;font-weight:600}.td-change,.td-price{text-align:right}.change-badge{align-items:center;border-radius:6px;display:inline-flex;font-size:.85rem;font-weight:600;gap:.25rem;padding:.375rem .625rem}.td-change.positive .change-badge{background:#10b9811a;color:var(--success-color)}.td-change.negative .change-badge{background:#ef44441a;color:var(--error-color)}.td-mcap,.td-volume{color:var(--text-secondary);font-family:SF Mono,Monaco,Consolas,monospace;font-size:.85rem;text-align:right}.td-exchange{color:var(--text-tertiary);font-size:.8rem;font-weight:600;text-align:center;text-transform:uppercase}.td-empty,.td-loading{color:var(--text-secondary);padding:4rem 2rem!important;text-align:center}.empty-state-wrapper,.loading-state-wrapper{align-items:center;display:flex;flex-direction:column;gap:1rem;justify-content:center;min-height:200px;text-align:center;width:100%}.empty-state-wrapper svg{color:var(--text-tertiary);opacity:.5}.empty-state-wrapper span,.loading-state-wrapper span{color:var(--text-secondary);font-size:1rem}.pagination{align-items:center;background:var(--bg-primary);display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;padding:1.5rem 2rem}.page-btn,.pagination-info{color:var(--text-secondary)}.page-btn{align-items:center;background:var(--card-bg);border:1px solid var(--border-color);border-radius:6px;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;justify-content:center;padding:.5rem .75rem;transition:all .2s}.page-btn:hover:not(:disabled){background:var(--bg-hover);border-color:var(--primary-color);color:var(--text-primary)}.page-btn:disabled{cursor:not-allowed;opacity:.4}.page-num{align-items:center;background:var(--card-bg);border:1px solid var(--border-color);border-radius:6px;color:var(--text-secondary);cursor:pointer;display:flex;font-size:.875rem;font-weight:600;height:36px;justify-content:center;min-width:36px;transition:all .2s}.page-num:hover{background:var(--bg-hover);color:var(--text-primary)}.page-num.active,.page-num:hover{border-color:var(--primary-color)}.page-num.active{background:var(--primary-color);color:#fff}.page-ellipsis{color:var(--text-tertiary);padding:0 .5rem}@media (max-width:1024px){.market-header-section{padding:1.5rem}.asset-tabs,.market-controls{padding:1rem 1.5rem}.market-table-wrapper{padding:0 1.5rem}.pagination{padding:1rem 1.5rem}}@media (max-width:768px){.market-header-section{flex-direction:column;gap:1rem;margin:0 1rem;padding:1.5rem}.market-header-section:hover{transform:none}.header-icon{height:48px;width:48px}.header-title{font-size:1.4rem}.header-subtitle{font-size:.875rem}.header-meta{gap:.5rem}.meta-item{font-size:.75rem;padding:.25rem .5rem}.asset-tabs{gap:.5rem;padding:.75rem 1rem}.asset-tab{font-size:.8rem;padding:.625rem 1rem}.market-controls{gap:.75rem;padding:.75rem 1rem}.search-box{max-width:100%;min-width:100%}.filter-select{flex:1 1;min-width:0}.favorites-btn{flex:1 1;justify-content:center}.market-table-wrapper{padding:0 1rem}.market-table td,.market-table th{font-size:.8rem;padding:.75rem .5rem}.symbol-name{display:none}.pagination{flex-direction:column;gap:.75rem;padding:1rem}.pagination-controls{flex-wrap:wrap;justify-content:center}.page-btn{padding:.5rem}}@media (max-width:480px){.asset-tab .tab-label{display:none}.asset-tab .tab-icon{font-size:1.25rem}.market-table td.td-mcap,.market-table td.td-volume,.market-table th.th-mcap,.market-table th.th-volume{display:none}}.advanced-chart-wrapper{background:var(--card-bg);border-radius:12px;box-shadow:0 2px 8px var(--card-shadow);padding:1rem;position:relative;width:100%}.advanced-chart-wrapper .recharts-wrapper{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.custom-chart-tooltip{background:var(--card-bg)!important;border:1px solid var(--border-color)!important;border-radius:8px!important;box-shadow:0 4px 12px var(--card-shadow-lg)!important;min-width:180px;padding:12px!important}.custom-chart-tooltip p{color:var(--text-primary);font-size:13px;font-weight:600;margin:0 0 8px}.custom-chart-tooltip div{color:var(--text-secondary);font-size:12px}.chart-info{background:var(--bg-secondary);border-radius:6px;color:var(--text-tertiary);font-size:11px;left:10px;padding:4px 8px;pointer-events:none;position:absolute;top:10px;z-index:10}.recharts-cartesian-axis-tick-value{fill:var(--text-secondary);font-size:11px}.recharts-cartesian-axis-line{stroke:var(--border-color)}.recharts-cartesian-grid-horizontal line,.recharts-cartesian-grid-vertical line{stroke:var(--border-color);opacity:.5}@media (max-width:768px){.advanced-chart-wrapper{padding:.5rem}.custom-chart-tooltip{min-width:150px;padding:8px!important}.custom-chart-tooltip p{font-size:12px}.custom-chart-tooltip div{font-size:11px}.chart-info{font-size:10px;padding:3px 6px}}.chart-loading,.chart-no-data{align-items:center;color:var(--text-secondary);display:flex;font-size:14px;height:100%;justify-content:center}.chart-no-data{flex-direction:column;gap:8px}.chart-no-data svg{opacity:.3}.market-detail-skeleton{background-color:var(--bg-primary);margin:0 auto;max-width:1600px;min-height:100vh;padding:2rem;width:100%}.market-detail-skeleton-header{justify-content:space-between;margin-bottom:2rem}.market-detail-skeleton-header,.skeleton-header-left{align-items:center;display:flex;gap:1.5rem}.skeleton-back-button{border-radius:14px}.skeleton-ticker-info{display:flex;flex-direction:column;gap:.5rem}.skeleton-ticker-symbol-row{align-items:center;display:flex;gap:1rem}.market-detail-skeleton-stats{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));margin-bottom:2rem}.skeleton-stat-card{border:1px solid var(--border-color);border-radius:20px;box-shadow:0 4px 6px -1px var(--card-shadow);justify-content:center;padding:1.5rem}.market-detail-skeleton-chart-section,.skeleton-stat-card{background:var(--card-bg);display:flex;flex-direction:column}.market-detail-skeleton-chart-section{border:1px solid var(--border-color);border-radius:24px;box-shadow:0 10px 15px -3px var(--card-shadow);gap:1.5rem;margin-bottom:2rem;padding:2rem}.skeleton-chart-toolbar{align-items:center;border-bottom:1px solid var(--border-color);display:flex;flex-wrap:wrap;gap:1.5rem;justify-content:space-between;padding-bottom:1.5rem}.skeleton-chart-controls{background:var(--bg-secondary);border-radius:12px;display:flex;gap:.5rem;padding:6px}.skeleton-chart-container{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;height:600px;overflow:hidden;width:100%}.market-detail-skeleton-info-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.skeleton-info-card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:16px;box-shadow:0 1px 3px var(--card-shadow);padding:1.5rem}@media (max-width:768px){.market-detail-skeleton{padding:1rem}.skeleton-ticker-symbol-row{align-items:flex-start;flex-direction:column}.market-detail-skeleton-info-grid,.market-detail-skeleton-stats{grid-template-columns:1fr}}.market-detail-container{background-color:var(--bg-primary);color:var(--text-primary);font-family:inherit;margin:0 auto;max-width:1600px;min-height:100vh;padding:2rem;width:100%}.market-detail-header-modern{align-items:center;display:flex;flex-wrap:wrap;gap:1.5rem;justify-content:space-between;margin-bottom:2rem}.btn-back-modern{align-items:center;background:var(--card-bg);border:1px solid var(--border-color);border-radius:14px;box-shadow:0 4px 6px -1px var(--card-shadow);color:var(--text-secondary);cursor:pointer;display:flex;height:48px;justify-content:center;transition:all .2s cubic-bezier(.4,0,.2,1);width:48px}.btn-back-modern:hover{background:var(--bg-hover);border-color:var(--primary-color);box-shadow:0 10px 15px -3px var(--card-shadow);color:var(--primary-color);transform:translateY(-2px)}.ticker-identity{display:flex;flex-direction:column}.ticker-symbol-row{align-items:center;display:flex;gap:1rem}.ticker-symbol-text{color:var(--text-primary);font-size:2.5rem;font-weight:800;letter-spacing:-.03em;line-height:1}.btn-favorite-modern{background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:4px;transition:all .2s}.btn-favorite-modern:hover{color:var(--warning-color);transform:scale(1.1)}.btn-favorite-modern.active{color:var(--warning-color);filter:drop-shadow(0 0 8px rgba(251,191,36,.5))}.ticker-name-text{color:var(--text-secondary);font-size:1.1rem;font-weight:500;margin-top:.5rem}.market-stats-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));margin-bottom:2rem}.stat-card-premium{background:var(--card-bg);border:1px solid var(--border-color);border-radius:20px;box-shadow:0 4px 6px -1px var(--card-shadow);display:flex;flex-direction:column;justify-content:center;padding:1.5rem;transition:transform .2s,box-shadow .2s}.stat-card-premium:hover{background:var(--bg-hover);border-color:var(--border-color-hover);box-shadow:0 20px 25px -5px var(--card-shadow-hover);transform:translateY(-4px)}.stat-label{font-size:.8rem;font-weight:600;gap:.5rem;margin-bottom:.75rem}.stat-label,.stat-value{align-items:center;display:flex}.stat-value{gap:.75rem}.chart-section-premium{background:var(--card-bg);border:1px solid var(--border-color);border-radius:24px;box-shadow:0 10px 15px -3px var(--card-shadow);display:flex;flex-direction:column;gap:1.5rem;margin-bottom:2rem;overflow:hidden;padding:2rem;position:relative}.chart-toolbar{align-items:center;border-bottom:1px solid var(--border-color);display:flex;flex-wrap:wrap;gap:1.5rem;justify-content:space-between;padding-bottom:1.5rem}.chart-controls-group{background:var(--bg-secondary);border-radius:12px;display:flex;gap:.5rem;padding:6px}.control-btn{background:#0000;border:none;border-radius:8px;color:var(--text-secondary);font-size:.9rem;font-weight:600;padding:8px 16px}.control-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.control-btn.active{background:var(--card-bg);box-shadow:0 2px 4px var(--card-shadow);color:var(--primary-color)}.chart-container-wrapper{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;height:600px;overflow:hidden;width:100%}.chart-skeleton-container{align-items:center;display:flex;height:100%;justify-content:center;padding:1rem;width:100%}.detail-info-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.info-item-card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:16px;box-shadow:0 1px 3px var(--card-shadow);padding:1.5rem}.info-card-label{color:var(--text-secondary);font-size:.9rem;font-weight:500;margin-bottom:.5rem}.info-card-value{color:var(--text-primary);font-size:1.25rem;font-weight:700}.loading-container{align-items:center;color:var(--text-secondary);display:flex;flex-direction:column;gap:1rem;height:80vh;justify-content:center}.error-container{background:var(--error-light);border:1px solid var(--error-color);margin:4rem auto;max-width:500px;padding:2rem}.news-page{background:var(--bg-primary);min-height:100vh;padding:0}.container{margin:0 auto;max-width:100%;padding:0 1.5rem;width:100%}.market-header-section{margin:0 1.5rem 2rem}.meta-separator{color:var(--border-color)}.action-btn svg.spinning{animation:spin 1s linear infinite}.news-last-updated{align-items:center;background:var(--bg-secondary);border-radius:.5rem;color:var(--text-secondary);display:inline-flex;font-size:.85rem;gap:.5rem;padding:.5rem 1rem}.error{background:var(--error-bg);border:1px solid var(--error-border)}.news-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(380px,1fr))}.news-card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:1rem;box-shadow:0 2px 8px var(--card-shadow);display:flex;flex-direction:column;overflow:hidden;transition:all .3s ease}.news-card:hover{border-color:var(--card-border-hover);box-shadow:0 8px 20px var(--card-shadow-hover);transform:translateY(-4px)}.news-image-wrapper{background:linear-gradient(135deg,var(--bg-tertiary) 0,var(--border-color-dark) 100%);height:220px;overflow:hidden;position:relative;width:100%}.news-image{height:100%;object-fit:cover;transition:transform .3s ease;width:100%}.news-card:hover .news-image{transform:scale(1.05)}.news-image-wrapper:after{background:linear-gradient(to top,var(--text-inverse-alpha-08),#0000);bottom:0;content:"";height:60px;left:0;position:absolute;right:0}.news-header{align-items:center;background:var(--bg-secondary);border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:1rem 1.5rem}.news-category{border-radius:1rem;color:#fff;font-size:.8rem;font-weight:600;letter-spacing:.5px;padding:.25rem .75rem;text-transform:uppercase}.news-time{align-items:center;color:var(--text-secondary);display:flex;font-size:.85rem;gap:.25rem}.news-content{flex:1 1;padding:1.5rem}.news-title{-webkit-line-clamp:2;color:var(--text-primary);font-size:1.2rem;font-weight:600;line-height:1.4;margin-bottom:.75rem}.news-summary,.news-title{-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.news-summary{-webkit-line-clamp:3;color:var(--text-secondary);font-size:.9rem;line-height:1.6}.news-footer{align-items:center;background:var(--bg-secondary);border-top:1px solid var(--border-color);display:flex;font-size:.85rem;justify-content:space-between;padding:1rem 1.5rem}.news-source{font-weight:500}.news-date,.news-source{color:var(--text-secondary)}.news-date{align-items:center;display:flex;gap:.25rem}.news-actions{border-top:1px solid var(--border-color-light);padding:1rem 1.5rem}.read-more-btn{align-items:center;background:var(--primary-color);border:none;border-radius:.5rem;color:#fff;cursor:pointer;display:flex;font-size:.9rem;font-weight:500;gap:.5rem;justify-content:center;padding:.75rem 1.5rem;transition:all .2s ease;width:100%}.read-more-btn:hover:not(:disabled){background:var(--primary-hover);box-shadow:0 4px 12px var(--primary-shadow);transform:translateY(-1px)}.read-more-btn:disabled{cursor:not-allowed;opacity:.5}.read-more-btn:disabled:hover{transform:none}.no-news{background:var(--card-bg);border:1px solid var(--card-border);border-radius:1rem;box-shadow:0 2px 8px var(--card-shadow);color:var(--text-secondary);padding:4rem 2rem;text-align:center}.no-news svg{color:var(--text-tertiary);margin-bottom:1rem;opacity:.5}.no-news h3{color:var(--text-primary);font-size:1.5rem;font-weight:600;margin-bottom:.5rem}.no-news p{color:var(--text-secondary);font-size:1rem}@media (max-width:1024px){.news-grid{gap:1.25rem;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}}@media (max-width:768px){.news-page{padding:calc(1rem + 80px) 0 1rem}.market-header-section{flex-direction:column;gap:1rem;margin:0 1rem 1.5rem;padding:1.5rem}.market-header-section:hover{transform:none}.header-icon{height:48px;width:48px}.header-title{font-size:1.4rem}.header-subtitle{font-size:.875rem}.header-meta{gap:.5rem}.meta-item{font-size:.75rem;padding:.25rem .5rem}.header-actions{justify-content:flex-start;width:100%}.news-header-modern{padding:1.25rem 1.5rem}.news-header-top{align-items:flex-start;flex-direction:column;gap:1rem}.news-title-modern{font-size:1.5rem}.refresh-btn-modern{justify-content:center;width:100%}.news-grid{gap:1rem;grid-template-columns:1fr}.news-footer,.news-header{align-items:flex-start;flex-direction:column;gap:.5rem}}@media (max-width:480px){.container{padding:0 1rem}.news-header-modern{padding:1rem}.news-icon-wrapper{height:40px;width:40px}.news-title-modern{font-size:1.25rem}.news-subtitle-modern{font-size:.85rem}.news-content{padding:1rem}.news-title{font-size:1.1rem}.news-actions{padding:1rem}.read-more-btn{font-size:.85rem;padding:.625rem 1rem}}.stock-list-table-container{background:#fff;background:var(--card-bg,#fff);border-radius:12px;box-shadow:0 2px 8px #0000000d;margin-bottom:2rem;overflow:hidden}.table-filters{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color,#e5e7eb);display:flex;flex-wrap:wrap;gap:1rem;padding:1.5rem}.filter-search{align-items:center;background:#f9fafb;background:var(--bg-secondary,#f9fafb);border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);border-radius:8px;display:flex;flex:1 1;gap:.75rem;min-width:250px;padding:.75rem 1rem;transition:all .2s}.filter-search:focus-within{background:#fff;border-color:#3b82f6;border-color:var(--primary-color,#3b82f6);box-shadow:0 0 0 3px #3b82f61a}.filter-search svg{color:#9ca3af;color:var(--text-tertiary,#9ca3af)}.filter-search-input{background:#0000;border:none;color:#1f2937;color:var(--text-primary,#1f2937);flex:1 1;font-size:.875rem;outline:none}.filter-search-input::placeholder{color:#9ca3af;color:var(--text-tertiary,#9ca3af)}.filter-dropdowns{display:flex;gap:.75rem}.filter-select{background:#f9fafb;background:var(--bg-secondary,#f9fafb);border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);border-radius:8px;color:#1f2937;color:var(--text-primary,#1f2937);cursor:pointer;font-size:.875rem;min-width:150px;padding:.75rem 1rem;transition:all .2s}.filter-select:hover{background:#fff}.filter-select:focus,.filter-select:hover{border-color:#3b82f6;border-color:var(--primary-color,#3b82f6)}.filter-select:focus{box-shadow:0 0 0 3px #3b82f61a;outline:none}.table-loading{align-items:center;display:flex;flex-direction:column;gap:1rem;justify-content:center;padding:4rem 2rem}.spinner{animation:spin .8s linear infinite;border:3px solid #e5e7eb;border-top-color:#3b82f6;border:3px solid var(--border-color,#e5e7eb);border-top-color:var(--primary-color,#3b82f6);height:40px;width:40px}.table-loading p{color:#6b7280;color:var(--text-secondary,#6b7280);font-size:.875rem}.table-empty{align-items:center;display:flex;flex-direction:column;gap:.5rem;justify-content:center;padding:4rem 2rem}.table-empty p{color:#1f2937;color:var(--text-primary,#1f2937);font-size:1rem;font-weight:500}.table-empty span{color:#6b7280;color:var(--text-secondary,#6b7280);font-size:.875rem}.stock-table{border-collapse:collapse;width:100%}.stock-table thead{background:#f9fafb;background:var(--bg-secondary,#f9fafb);border-bottom:2px solid #e5e7eb;border-bottom:2px solid var(--border-color,#e5e7eb)}.stock-table th{color:#6b7280;color:var(--text-secondary,#6b7280);font-size:.75rem;font-weight:600;letter-spacing:.05em;padding:1rem 1.5rem;text-align:left;text-transform:uppercase;white-space:nowrap}.stock-table .th-ticker{width:20%}.stock-table .th-currency{text-align:center;width:15%}.stock-table .th-exchange,.stock-table .th-type{text-align:center;width:20%}.stock-table .th-actions{text-align:center;width:25%}.stock-table th.sortable{cursor:pointer;transition:background .2s;-webkit-user-select:none;user-select:none}.stock-table th.sortable:hover{background:#f3f4f6;background:var(--bg-tertiary,#f3f4f6)}.th-content{gap:.5rem}.th-content svg{opacity:.3;transition:opacity .2s}.th-content svg.active{color:#3b82f6;color:var(--primary-color,#3b82f6);opacity:1}.stock-table tbody tr{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color,#e5e7eb);transition:background .2s}.stock-table tbody tr:hover{background:#f9fafb;background:var(--bg-secondary,#f9fafb)}.stock-table tbody tr.selected{background:#3b82f60d;border-left:3px solid #3b82f6;border-left:3px solid var(--primary-color,#3b82f6)}.stock-table td{color:#1f2937;color:var(--text-primary,#1f2937);font-size:.875rem;padding:1rem 1.5rem}.ticker-cell{font-weight:600}.ticker-badge{background:#3b82f6;background:var(--primary-color,#3b82f6);border-radius:6px;color:#fff;display:inline-block;font-size:.75rem;font-weight:700;letter-spacing:.05em;padding:.25rem .75rem}.name-cell{max-width:250px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.currency-cell{text-align:center}.currency-badge{border-radius:6px;display:inline-block;font-size:.75rem;font-weight:600;padding:.25rem .75rem}.currency-badge.idr{background:#dbeafe;color:#1e40af}.currency-badge.usd{background:#dcfce7;color:#166534}.type-cell{color:#6b7280;color:var(--text-secondary,#6b7280);text-align:center}.type-badge,.type-cell{text-transform:capitalize}.type-badge{background:#f3f4f6;background:var(--bg-tertiary,#f3f4f6);border-radius:6px;display:inline-block;font-size:.75rem;font-weight:500;padding:.25rem .75rem}.exchange-cell{color:#6b7280;color:var(--text-secondary,#6b7280);font-size:.8125rem;text-align:center}.exchange-badge{background:#f3f4f6;background:var(--bg-tertiary,#f3f4f6);border-radius:6px;display:inline-block;font-size:.75rem;font-weight:500;padding:.25rem .75rem}.actions-cell{text-align:center}.select-btn{background:#3b82f6;background:var(--primary-color,#3b82f6);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.875rem;font-weight:500;padding:.5rem 1.25rem;transition:all .2s}.select-btn:hover{background:#2563eb;background:var(--primary-dark,#2563eb);box-shadow:0 4px 8px #3b82f64d;transform:translateY(-1px)}.select-btn:active{transform:translateY(0)}.table-pagination{border-top:1px solid #e5e7eb;border-top:1px solid var(--border-color,#e5e7eb);flex-wrap:wrap;gap:1rem;justify-content:space-between;padding:1.5rem}.pagination-info{color:#6b7280;color:var(--text-secondary,#6b7280);font-size:.875rem}.pagination-btn,.pagination-controls{align-items:center;display:flex;gap:.5rem}.pagination-btn{background:#f9fafb;background:var(--bg-secondary,#f9fafb);border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);border-radius:6px;color:#1f2937;color:var(--text-primary,#1f2937);font-size:.875rem;padding:.5rem 1rem;transition:all .2s}.pagination-btn:hover:not(:disabled){background:#fff;border-color:#3b82f6;border-color:var(--primary-color,#3b82f6);color:#3b82f6;color:var(--primary-color,#3b82f6)}.pagination-pages{display:flex;gap:.25rem}.pagination-page{background:#f9fafb;background:var(--bg-secondary,#f9fafb);border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);border-radius:6px;color:#1f2937;color:var(--text-primary,#1f2937);cursor:pointer;font-size:.875rem;height:36px;min-width:36px;padding:.5rem;transition:all .2s}.pagination-page:hover{background:#fff;color:#3b82f6;color:var(--primary-color,#3b82f6)}.pagination-page.active,.pagination-page:hover{border-color:#3b82f6;border-color:var(--primary-color,#3b82f6)}.pagination-page.active{background:#3b82f6;background:var(--primary-color,#3b82f6);color:#fff;font-weight:600}@media (max-width:768px){.table-filters{flex-direction:column}.filter-search{min-width:100%}.filter-dropdowns{flex-direction:column;width:100%}.filter-select{width:100%}.stock-table{font-size:.8125rem}.stock-table td,.stock-table th{padding:.75rem 1rem}.table-pagination{align-items:flex-start;flex-direction:column}.pagination-controls{justify-content:space-between;width:100%}}.fundamental-page{background:var(--bg-primary);min-height:100vh}.market-header-section{align-items:flex-start;background:var(--card-bg);border:1px solid var(--border-color);border-radius:16px;box-shadow:0 4px 20px var(--card-shadow);display:flex;gap:1.5rem;margin:0 0 2rem;overflow:hidden;padding:2rem 2.5rem;position:relative;transition:all .3s ease}.market-header-section.compact{align-items:center;padding:1.25rem 2rem}.market-header-section.compact .header-icon{height:48px;width:48px}.market-header-section.compact .header-title{font-size:1.5rem;margin-bottom:.25rem}.market-header-section.compact .header-subtitle{font-size:.875rem;margin:0}.header-meta-inline{align-items:center;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-secondary);display:flex;font-size:.8rem;gap:.5rem;margin-left:auto;padding:.5rem 1rem;white-space:nowrap}.market-header-section:before{background:var(--gradient-primary);content:"";height:4px;left:0;position:absolute;right:0;top:0}.market-header-section:hover{box-shadow:0 8px 30px var(--card-shadow-hover);transform:translateY(-2px)}.header-icon{background:var(--primary-color);border-radius:14px;box-shadow:0 4px 12px var(--primary-shadow-md);font-size:1.5rem;height:56px;width:56px}.header-content{flex:1 1}.header-title{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,var(--text-primary) 0,var(--primary-color) 100%);-webkit-background-clip:text;background-clip:text;font-size:1.75rem;font-weight:800;margin:0 0 .5rem}.header-subtitle{margin:0 0 .75rem}.header-meta{color:var(--text-tertiary);flex-wrap:wrap;font-size:.85rem;gap:1rem}.header-meta,.meta-item{align-items:center;display:flex}.meta-item{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:20px;gap:6px;padding:.375rem .75rem}.header-actions{flex-shrink:0}.action-btn{align-items:center;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-secondary);cursor:pointer;display:flex;font-size:.875rem;font-weight:600;gap:6px;padding:.625rem 1.25rem;transition:all .2s}.action-btn:hover:not(:disabled){background:var(--bg-hover);color:var(--text-primary)}.action-btn.primary{background:var(--primary-color);border-color:var(--primary-color);color:#fff}.action-btn.primary:hover:not(:disabled){background:var(--primary-hover)}.action-btn:disabled{cursor:not-allowed;opacity:.5}.fundamental-content{padding:0 2rem 2rem}.fundamental-data-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(2,1fr)}.data-section{background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;box-shadow:0 2px 8px var(--card-shadow);padding:1.5rem}.data-section.full-width{grid-column:1/-1}.data-section .section-header{align-items:center;border-bottom:2px solid var(--border-color);display:flex;gap:.75rem;margin-bottom:1.25rem;padding-bottom:1rem}.data-section .section-header svg{color:var(--primary-color);flex-shrink:0}.data-section .section-header h3{color:var(--text-primary);font-size:1rem;font-weight:700;margin:0}.data-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.data-item{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;display:flex;flex-direction:column;gap:.375rem;padding:.875rem;transition:all .2s}.data-item:hover{background:var(--bg-hover);border-color:var(--primary-color)}.data-item.highlight{background:var(--primary-color);border-color:var(--primary-color)}.data-item.highlight .data-label,.data-item.highlight .data-value{color:#fff}.data-label{color:var(--text-tertiary);font-size:.75rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.data-value{color:var(--text-primary);font-size:1rem;font-weight:700;word-break:break-word}.data-item.rec-strong-buy .data-value{color:var(--success-color)}.data-item.rec-buy .data-value{color:#22c55e}.data-item.rec-hold .data-value{color:var(--warning-color)}.data-item.rec-sell .data-value{color:#f97316}.data-item.rec-strong-sell .data-value{color:var(--error-color)}.empty-state,.error-container,.loading-container{align-items:center;background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;color:var(--text-secondary);display:flex;flex-direction:column;justify-content:center;padding:5rem 2rem;text-align:center}.error-container{color:var(--error-color)}.empty-icon{color:var(--text-tertiary);margin-bottom:1.5rem;opacity:.5}.empty-state h3{color:var(--text-primary);font-size:1.25rem;margin:0 0 .5rem}.empty-state p{color:var(--text-secondary);font-size:.95rem}.modal-content{animation:slideInUp .3s;max-width:480px;width:90%}@keyframes slideInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.btn-close{align-items:center;background:var(--bg-secondary);border:1px solid var(--border-color);display:flex;height:36px;justify-content:center;transition:all .2s;width:36px}.btn-close:hover{background:var(--bg-hover)}.alert-form{display:flex;flex-direction:column;gap:1.25rem;padding:1.5rem}.form-group label{color:var(--text-secondary)}.form-input,.form-select{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-size:.95rem;padding:.75rem 1rem;transition:all .2s}.form-input:focus,.form-select:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px #2962ff1a;outline:none}.modal-actions{padding-top:.5rem}.btn-primary,.btn-secondary{align-items:center;display:flex;font-size:.875rem;gap:.5rem;padding:.75rem 1.25rem;transition:all .2s}.btn-secondary:hover{background:var(--bg-hover)}@media (max-width:1024px){.fundamental-data-grid{grid-template-columns:1fr}.data-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.market-header-section{flex-direction:column;gap:1rem;margin:0 1rem 1.5rem;padding:1.5rem}.market-header-section:hover{transform:none}.header-icon{height:48px;width:48px}.header-title{font-size:1.4rem}.header-subtitle{font-size:.875rem}.header-meta{gap:.5rem}.meta-item{font-size:.75rem;padding:.25rem .5rem}.header-actions{justify-content:flex-start;width:100%}.action-btn{flex:1 1;justify-content:center}.fundamental-content{padding:0 1rem 1rem}.data-section{padding:1rem}.data-grid{grid-template-columns:1fr}.modal-content{margin:1rem;width:95%}}@media (max-width:480px){.header-title{font-size:1.25rem}.header-subtitle{font-size:.85rem}.data-item{padding:.75rem}.data-value{font-size:.9rem}}.data-value-wrapper{align-items:center;display:flex;flex-wrap:wrap;gap:.5rem;justify-content:flex-end}.quality-badge{align-items:center;border-radius:6px;display:inline-flex;font-size:.7rem;font-weight:600;gap:.35rem;letter-spacing:.5px;line-height:1;padding:.25rem .5rem;text-transform:uppercase}.quality-badge.success{background:#10b9811a;border:1px solid #10b98133;color:#10b981}.quality-badge.warning{background:#f59e0b1a;border:1px solid #f59e0b33;color:#f59e0b}.quality-badge.danger{background:#ef44441a;border:1px solid #ef444433;color:#ef4444}.quality-badge.info{background:#3b82f61a;border:1px solid #3b82f633;color:#3b82f6}.technical-page{background:var(--bg-primary);min-height:100vh;padding:2rem 0}.page-header{background:var(--card-bg);border-radius:1rem;box-shadow:0 4px 6px var(--card-shadow);margin-bottom:3rem;padding:2rem 0;text-align:center}.page-header h1{align-items:center;color:var(--text-primary);display:flex;font-size:2.5rem;gap:1rem;justify-content:center;margin-bottom:.5rem}.page-header p{color:var(--text-secondary);font-size:1.1rem}.error,.loading{color:var(--text-secondary);font-size:1.2rem;padding:3rem;text-align:center}.error{border:1px solid var(--error-color)}.stock-selector{background:var(--card-bg);border-radius:1rem;box-shadow:0 4px 6px var(--card-shadow);margin-bottom:2rem;padding:2rem}.stock-selector h3{color:var(--text-primary);font-size:1.5rem;font-weight:600;margin-bottom:1.5rem}.symbol-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.symbol-btn{align-items:center;background:var(--card-bg);border:2px solid var(--border-color);border-radius:.75rem;cursor:pointer;display:flex;flex-direction:column;padding:1.5rem;text-align:center;transition:all .3s ease}.symbol-btn:hover{border-color:var(--info-color);box-shadow:0 4px 8px var(--card-shadow-hover);transform:translateY(-2px)}.symbol-btn.active{background:var(--info-light);border-color:var(--info-color)}.symbol-btn .symbol{color:var(--text-primary);font-size:1.5rem;font-weight:700;margin-bottom:.5rem}.symbol-btn .name{color:var(--text-secondary);font-size:.9rem;line-height:1.3;text-align:center}.signal-card{border-radius:1rem;box-shadow:0 4px 6px var(--card-shadow);margin-bottom:2rem;padding:2rem;text-align:center}.signal-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.signal-header h2{color:var(--text-primary);font-size:1.8rem;font-weight:600}.signal-badge{border-radius:2rem;color:var(--text-inverse);display:flex;font-size:1.1rem;gap:.5rem;padding:.75rem 1.5rem}.signal-card p{color:var(--text-secondary);font-size:1rem}.indicators-section{background:var(--card-bg);border:1px solid var(--card-border);border-radius:1rem;box-shadow:0 4px 6px var(--card-shadow);margin-bottom:2rem;padding:2rem}.indicators-section h2{color:var(--text-primary);font-size:1.8rem;font-weight:600;margin-bottom:1.5rem}.indicators-grid{grid-gap:1.5rem;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.indicator-card{background:var(--bg-secondary);border:1px solid var(--card-border);border-radius:.75rem;padding:1.5rem;transition:all .3s ease}.indicator-card:hover{box-shadow:0 4px 8px var(--card-shadow-hover)}.indicator-header{color:var(--info-color);gap:.75rem;margin-bottom:1rem}.indicator-header h3{color:var(--text-primary);font-size:1.1rem;font-weight:600}.indicator-value{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.indicator-value .value{color:var(--text-primary);font-size:1.8rem;font-weight:700}.indicator-value .status{background:var(--info-light);border-radius:1rem;font-size:.9rem;font-weight:600;padding:.25rem .75rem}.rsi-bar{background:var(--border-color);border-radius:4px;height:8px;margin-bottom:.75rem;overflow:hidden;width:100%}.rsi-fill{border-radius:4px;height:100%;transition:width .3s ease}.indicator-card p{color:var(--text-secondary);font-size:.85rem;line-height:1.4}.moving-averages{background:var(--card-bg);border:1px solid var(--card-border);border-radius:1rem;box-shadow:0 4px 6px var(--card-shadow);margin-bottom:2rem;padding:2rem}.moving-averages h2{color:var(--text-primary);font-size:1.8rem;font-weight:600;margin-bottom:1.5rem}.ma-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.ma-card{background:var(--bg-secondary);border:1px solid var(--card-border);border-radius:.75rem;padding:1.5rem;text-align:center;transition:all .3s ease}.ma-card:hover{box-shadow:0 4px 8px var(--card-shadow-hover);transform:translateY(-2px)}.ma-card h4{color:var(--text-secondary);font-size:1rem;font-weight:600;margin-bottom:.75rem}.ma-value{color:var(--text-primary);font-size:1.5rem;font-weight:700}.bollinger-bands{background:var(--card-bg);border:1px solid var(--card-border);border-radius:1rem;box-shadow:0 4px 6px var(--card-shadow);margin-bottom:2rem;padding:2rem}.bollinger-bands h2{color:var(--text-primary);font-size:1.8rem;font-weight:600;margin-bottom:1.5rem}.bb-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.bb-card{border:1px solid var(--card-border);border-radius:.75rem;padding:1.5rem;text-align:center;transition:all .3s ease}.bb-card.upper{background:var(--error-light);border-color:var(--error-color)}.bb-card.middle{background:var(--info-light);border-color:var(--info-color)}.bb-card.lower{background:var(--success-light);border-color:var(--success-color)}.bb-card:hover{box-shadow:0 4px 8px var(--card-shadow-md);transform:translateY(-2px)}.bb-card h4{font-size:1rem;font-weight:600;margin-bottom:.75rem}.bb-card h4,.bb-value{color:var(--text-primary)}.bb-value{font-size:1.5rem;font-weight:700}.support-resistance{background:var(--card-bg);border:1px solid var(--card-border);border-radius:1rem;box-shadow:0 4px 6px var(--card-shadow);margin-bottom:2rem;padding:2rem}.support-resistance h2{color:var(--text-primary);font-size:1.8rem;font-weight:600;margin-bottom:1.5rem}.sr-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.sr-card{background:var(--bg-secondary);border:1px solid var(--card-border);border-radius:.75rem;padding:1.5rem;transition:all .3s ease}.sr-card.support{border-left:4px solid var(--success-color)}.sr-card.resistance{border-left:4px solid var(--error-color)}.sr-card:hover{box-shadow:0 4px 8px var(--card-shadow-md);transform:translateY(-2px)}.sr-header{align-items:center;color:var(--info-color);display:flex;gap:.75rem;margin-bottom:1rem}.sr-header h3{font-size:1.1rem;font-weight:600}.sr-header h3,.sr-value{color:var(--text-primary)}.sr-value{font-size:1.8rem;font-weight:700;margin-bottom:.75rem}.sr-card p{color:var(--text-secondary);font-size:.85rem;line-height:1.4}.analysis-summary{background:var(--card-bg);border-radius:1rem;box-shadow:0 4px 6px var(--card-shadow);padding:2rem}.analysis-summary h2{color:var(--text-primary);font-size:1.8rem;font-weight:600;margin-bottom:1.5rem}.summary-content{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.summary-item{border:1px solid var(--card-border);border-radius:.75rem;padding:1.5rem;text-align:center}.summary-item h4{color:var(--text-primary);font-size:1.1rem;font-weight:600;margin-bottom:1rem}.momentum-indicator,.trend-indicator,.volatility-indicator{align-items:center;color:var(--text-primary);display:flex;font-weight:600;gap:.5rem;justify-content:center}@media (max-width:768px){.technical-page{padding:1rem 0}.page-header h1{flex-direction:column;font-size:2rem;gap:.5rem}.symbol-grid{grid-template-columns:repeat(2,1fr)}.bb-grid,.indicators-grid,.ma-grid,.sr-grid,.summary-content{grid-template-columns:1fr}.signal-header{flex-direction:column;gap:1rem;text-align:center}}@media (max-width:480px){.symbol-grid{grid-template-columns:1fr}.symbol-btn{padding:1rem}.symbol-btn .symbol{font-size:1.25rem}.analysis-summary,.bollinger-bands,.indicators-section,.moving-averages,.support-resistance{padding:1.5rem}.bb-card,.indicator-card,.ma-card,.sr-card{padding:1rem}.indicator-value .value{font-size:1.5rem}.bb-value,.ma-value{font-size:1.25rem}.sr-value{font-size:1.5rem}}.technical-dashboard{background:var(--bg-primary);color:var(--text-primary);padding:1.5rem}.dashboard-container{background:var(--card-bg);border:1px solid var(--border-color);border-radius:20px;box-shadow:0 20px 60px var(--card-shadow-hover);max-width:95%;overflow:hidden;width:100%}@media (min-width:1920px){.dashboard-container{max-width:1800px}}@media (min-width:2560px){.dashboard-container{max-width:2400px}}.dashboard-header{background:var(--bg-secondary);border-bottom:1px solid var(--border-color);color:var(--text-primary);padding:2.5rem;text-align:center}.dashboard-header h1{color:var(--text-primary);font-size:2.5rem;gap:1rem;justify-content:center;margin:0 0 .5rem}.dashboard-header p{color:var(--text-secondary);font-size:1.1rem;margin:0;opacity:.9}.control-panel{background:var(--bg-tertiary);border-bottom:1px solid var(--border-color);padding:2rem}.control-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-bottom:2rem}.control-group{background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;box-shadow:0 2px 8px var(--card-shadow);padding:1.5rem}.control-group h3{align-items:center;color:var(--text-primary);display:flex;font-size:1.1rem;font-weight:600;gap:.5rem;margin:0 0 1rem}.control-group label{color:var(--text-secondary);display:block;font-size:.9rem;font-weight:500;margin-bottom:.5rem}.control-group input,.control-group select{background:var(--bg-primary);border:2px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-size:1rem;padding:.75rem;transition:all .3s;width:100%}.control-group input:focus,.control-group select:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px var(--primary-light);outline:none}.indicators-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.indicator-card{background:var(--card-bg);border:2px solid var(--border-color);border-radius:10px;color:var(--text-primary);cursor:pointer;padding:1rem;transition:all .3s}.indicator-card:hover{border-color:var(--primary-color);box-shadow:0 4px 12px var(--card-shadow-hover);transform:translateY(-2px)}.indicator-card.selected{background:var(--primary-light);border-color:var(--primary-color)}.indicator-card label{cursor:pointer;font-weight:500}.indicator-card small{color:var(--text-tertiary);display:block;font-size:.85rem;margin-top:.25rem}.action-buttons{gap:1rem;justify-content:center;margin-top:2rem}.btn{border-radius:10px;padding:1rem 2rem;transition:all .3s}.btn-primary:hover:not(:disabled){box-shadow:0 8px 20px var(--card-shadow-hover)}.btn-primary:disabled{cursor:not-allowed;opacity:.6}.tabs-container{background:var(--bg-secondary);border-bottom:2px solid var(--border-color)}.tabs{padding:0 2rem}.tab{color:var(--text-secondary);padding:1.25rem 2rem;transition:all .3s}.tab.active,.tab:hover{background:var(--bg-hover);color:var(--primary-color)}.tab.active{border-bottom-color:var(--primary-color)}.tab-content{min-height:500px}.empty-state{padding:4rem}.empty-state svg{color:var(--text-tertiary);margin-bottom:1rem}.empty-state h3{color:var(--text-secondary);margin:1rem 0 .5rem}.stat-card{box-shadow:0 4px 12px var(--card-shadow);color:var(--text-primary)}.stat-card h4{color:var(--text-secondary);font-size:.9rem;font-weight:500;margin:0 0 .5rem;opacity:.9}.stat-card .value{color:var(--text-primary);font-size:2rem;font-weight:700;margin:.5rem 0}.stat-card .change{align-items:center;display:flex;font-size:.9rem;gap:.25rem;margin-top:.5rem}.stat-card .change.positive{color:var(--success-color)}.stat-card .change.negative{color:var(--error-color)}.card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;box-shadow:0 2px 8px var(--card-shadow);padding:1.5rem}.card,.card-header{margin-bottom:1.5rem}.card-header{border-bottom:2px solid var(--border-color);padding-bottom:1rem}.card-header h3{align-items:center;color:var(--text-primary);display:flex;font-size:1.3rem;font-weight:600;gap:.5rem;margin:0}.card-body{padding:0}.summary-grid{grid-gap:1rem;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.summary-item{background:var(--bg-secondary);border:1px solid var(--border-color);padding:.75rem}.summary-item .label{color:var(--text-secondary);font-weight:500}.summary-item .value{color:var(--text-primary);font-weight:600}.voting-preview-card{background:var(--bg-secondary);border:2px solid var(--primary-color);border-radius:12px;margin-bottom:2rem;padding:1.5rem}.voting-preview{text-align:center}.voting-result{font-size:3rem;font-weight:700;margin:1rem 0;text-transform:uppercase}.voting-result.buy{color:var(--success-color)}.voting-result.sell{color:var(--error-color)}.voting-result.hold{color:var(--warning-color)}.voting-stats-mini{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(4,1fr);margin-top:1.5rem}.stat-mini{background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;padding:1rem;text-align:center}.stat-mini .label{color:var(--text-secondary);display:block;font-size:.85rem;margin-bottom:.5rem}.stat-mini .value{color:var(--text-primary);display:block;font-size:1.5rem;font-weight:700}.stat-mini .value.buy{color:var(--success-color)}.stat-mini .value.sell{color:var(--error-color)}.stat-mini .value.hold{color:var(--warning-color)}.performance-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.performance-card{background:var(--card-bg);border:2px solid var(--border-color);border-radius:12px;padding:1.5rem;transition:all .3s}.performance-card:hover{border-color:var(--primary-color);box-shadow:0 4px 12px var(--card-shadow-hover);transform:translateY(-2px)}.performance-card h4{color:var(--text-primary);font-size:1.1rem;font-weight:600;margin:0 0 1rem}.performance-metrics{display:flex;flex-direction:column;gap:.75rem}.performance-metric{align-items:center;border-bottom:1px solid var(--border-color-light);display:flex;justify-content:space-between;padding:.5rem 0}.performance-metric:last-child{border-bottom:none}.performance-metric-label{color:var(--text-secondary);font-size:.9rem}.performance-metric-value{color:var(--text-primary);font-size:1rem;font-weight:600}.performance-metric-value.positive{color:var(--success-color)}.performance-metric-value.negative{color:var(--error-color)}.voting-card{background:var(--bg-tertiary);border:2px solid var(--primary-color);border-radius:12px;margin-bottom:2rem;padding:2rem}.voting-header{margin-bottom:2rem;text-align:center}.voting-header h3{color:var(--primary-color);font-size:1.5rem;font-weight:700;margin:0 0 1.5rem}.confidence-bar{background:var(--bg-secondary);border-radius:6px;height:12px;margin:1rem 0;width:100%}.confidence-fill{background:linear-gradient(90deg,var(--success-color) 0,var(--primary-color) 50%,var(--error-color) 100%);transition:width .5s ease}.confidence-text{color:var(--primary-color);font-size:1.1rem;font-weight:600;margin:.5rem 0 0}.voting-stats{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(3,1fr);margin-top:2rem}.voting-stat{background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;box-shadow:0 2px 8px var(--card-shadow);padding:1.5rem;text-align:center}.voting-stat.buy{border-left:4px solid var(--success-color)}.voting-stat.sell{border-left:4px solid var(--error-color)}.voting-stat.hold{border-left:4px solid var(--warning-color)}.voting-stat-value{font-size:2.5rem;font-weight:700;margin-bottom:.5rem}.voting-stat.buy .voting-stat-value{color:var(--success-color)}.voting-stat.sell .voting-stat-value{color:var(--error-color)}.voting-stat.hold .voting-stat-value{color:var(--warning-color)}.voting-stat-label{color:var(--text-secondary);font-size:.9rem;font-weight:500}.volume-filter-info{align-items:center;background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;color:var(--primary-color);display:flex;font-weight:500;gap:.5rem;justify-content:center;margin-top:1.5rem;padding:1rem}.signals-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.signal-card{background:var(--card-bg);border:2px solid var(--border-color);border-radius:10px;padding:1rem;transition:all .3s}.signal-card:hover{box-shadow:0 4px 12px var(--card-shadow-hover)}.signal-card-header{align-items:center;display:flex;justify-content:space-between}.signal-card-header h4{color:var(--text-primary);font-size:1rem;font-weight:600;margin:0}.signal-badge{border-radius:20px;padding:.4rem .8rem}.signal-badge.hold{background:var(--warning-light);color:var(--warning-color)}.table-responsive{overflow-x:auto}.data-table{margin-top:1rem}.data-table td,.data-table th{border-bottom:1px solid var(--border-color);padding:1rem;text-align:left}.data-table th{background:var(--bg-secondary);color:var(--text-primary)}.data-table tr:hover{background:var(--bg-hover)}.chart-container{box-shadow:0 2px 8px var(--card-shadow);margin-bottom:2rem}.chart-container h3{color:var(--text-primary);font-size:1.2rem;font-weight:600;margin:0 0 1.5rem}.loading-overlay{color:var(--primary-color);padding:4rem}.loading-overlay p{color:var(--text-secondary);margin-top:1rem}@media (max-width:768px){.technical-dashboard{padding:1rem}.dashboard-header h1{font-size:1.8rem}.control-grid{grid-template-columns:1fr}.tabs{padding:0 1rem}.tab{font-size:.9rem}.tab,.tab-content{padding:1rem}.performance-grid,.signals-grid,.stats-grid,.voting-stats{grid-template-columns:1fr}.voting-stats-mini{grid-template-columns:repeat(2,1fr)}}.bulk-analysis-container{margin:0 auto;max-width:1800px;min-height:100vh;padding:28px}.bulk-header-section{background:var(--gradient-primary);border-radius:20px;box-shadow:0 10px 30px var(--primary-shadow-hover);color:var(--text-inverse);margin-bottom:32px;padding:40px}.bulk-header-content h1{align-items:center;display:flex;font-size:32px;font-weight:800;gap:16px;letter-spacing:-.5px;margin:0 0 12px}.bulk-subtitle{font-size:16px;line-height:1.6;margin:0;max-width:700px;opacity:.95}.bulk-header-stats{display:flex;flex-wrap:wrap;gap:20px;margin-top:24px}.header-stat-card{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:var(--text-inverse-alpha-015);border:1px solid var(--text-inverse-alpha-02);border-radius:12px;display:flex;gap:16px;padding:20px 28px;transition:all .3s ease}.header-stat-card:hover{background:var(--text-inverse-alpha-025);transform:translateY(-2px)}.stat-number{font-size:28px;font-weight:800;line-height:1;margin-bottom:4px}.stat-label{opacity:.9}.backtest-charts-section{background:var(--card-bg);border-radius:16px;box-shadow:0 4px 12px var(--card-shadow-sm);margin-top:32px;padding:28px}.backtest-charts-section h3{color:var(--text-primary);font-size:22px;font-weight:700;margin:0 0 24px}.charts-grid{grid-gap:24px;gap:24px;grid-template-columns:repeat(auto-fit,minmax(500px,1fr));margin-top:24px}.chart-box{background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:12px;padding:20px;transition:all .3s ease}.chart-box:hover{border-color:var(--primary-color);box-shadow:0 4px 16px var(--primary-color-alpha-01)}.chart-box h4{color:var(--text-secondary);font-size:15px;font-weight:600;margin:0 0 16px;text-align:center}.bulk-config-panel{background:linear-gradient(135deg,var(--card-bg) 0,var(--bg-secondary) 100%);border:2px solid var(--primary-color-alpha-01);border-radius:20px;box-shadow:0 8px 24px var(--card-shadow-md);margin-bottom:32px;padding:32px;transition:all .3s ease}.bulk-config-panel:hover{border-color:var(--primary-color-alpha-02);box-shadow:0 12px 32px var(--primary-shadow-md)}.config-section{margin-bottom:32px}.config-section h3{align-items:center;color:var(--text-primary);display:flex;font-size:20px;font-weight:700;gap:10px;letter-spacing:-.3px;margin-bottom:20px}.config-section h4{color:var(--text-secondary);font-size:14px;margin:16px 0 12px}.select-all-btn{background:var(--bg-tertiary);border:none;border-radius:6px;color:var(--text-primary);cursor:pointer;font-size:13px;margin-bottom:12px;padding:8px 16px;transition:all .2s}.select-all-btn:hover{background:var(--border-color-dark)}.indicator-grid,.ticker-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));margin-bottom:12px}.indicator-checkbox,.ticker-checkbox{align-items:flex-start;background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:8px;cursor:pointer;display:flex;gap:10px;padding:12px;transition:all .2s}.indicator-checkbox:hover,.ticker-checkbox:hover{background:#edf2f7;border-color:var(--border-color-dark)}.indicator-checkbox input,.ticker-checkbox input{cursor:pointer;margin-top:2px}.indicator-info,.ticker-info{display:flex;flex-direction:column;gap:2px}.indicator-info strong,.ticker-info strong{color:var(--text-primary);font-size:14px}.indicator-info small,.ticker-info small{color:var(--text-tertiary);font-size:12px}.selection-summary{background:var(--info-light);border-left:4px solid var(--info-color);border-radius:4px;color:var(--info-color);font-size:14px;padding:12px}.selection-summary strong{color:var(--info-hover);font-weight:600}.config-inputs{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.input-group{flex-direction:column;gap:6px}.input-group label{color:var(--text-secondary);font-size:13px;font-weight:500}.input-group input,.input-group select{border:1px solid var(--border-color);border-radius:6px;font-size:14px;padding:10px;transition:border-color .2s}.input-group input:focus,.input-group select:focus{border-color:var(--info-color);outline:none}.advanced-params{border-top:1px solid var(--border-color);margin-top:24px;padding-top:24px}.action-buttons{flex-wrap:wrap;gap:12px;margin-top:24px}.export-btn,.run-analysis-btn,.run-backtest-btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;padding:12px 24px;transition:all .2s}.run-analysis-btn{background:var(--gradient-primary);color:var(--text-inverse);overflow:hidden;position:relative}.run-analysis-btn:before{background:linear-gradient(90deg,#0000,var(--text-inverse-alpha-03),#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .5s;width:100%}.run-analysis-btn:hover:not(:disabled):before{left:100%}.run-analysis-btn:hover:not(:disabled){box-shadow:0 8px 20px var(--primary-shadow-hover);transform:translateY(-3px)}.run-backtest-btn{background:linear-gradient(135deg,var(--secondary-color) 0,var(--error-color) 100%);overflow:hidden;position:relative}.run-backtest-btn:before{background:linear-gradient(90deg,#0000,var(--text-inverse-alpha-03),#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .5s;width:100%}.run-backtest-btn:hover:not(:disabled):before{left:100%}.run-backtest-btn:hover:not(:disabled){box-shadow:0 8px 20px var(--error-color-alpha-02);transform:translateY(-3px)}.export-btn{background:var(--success-color)}.export-btn:hover{background:var(--success-hover)}.run-analysis-btn:disabled,.run-backtest-btn:disabled{cursor:not-allowed;opacity:.5;transform:none}.bulk-results-panel{animation:fadeIn .5s ease-in-out;background:linear-gradient(135deg,var(--card-bg) 0,var(--bg-secondary) 100%);border:2px solid var(--primary-color-alpha-01);border-radius:20px;box-shadow:0 8px 24px var(--card-shadow-md);padding:32px}.results-tabs{border-bottom:2px solid var(--border-color);display:flex;gap:8px;margin-bottom:24px}.results-tabs button{background:none;border:none;border-bottom:2px solid #0000;color:var(--text-tertiary);cursor:pointer;font-size:14px;font-weight:500;margin-bottom:-2px;padding:12px 24px;transition:all .2s}.results-tabs button:hover:not(:disabled){color:var(--text-primary)}.results-tabs button.active{border-bottom-color:var(--info-color);color:var(--info-color)}.results-tabs button:disabled{cursor:not-allowed;opacity:.4}.summary-cards{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:24px}.summary-card{background:var(--gradient-primary);border-radius:16px;box-shadow:0 4px 12px var(--primary-shadow-md);color:var(--text-inverse);padding:24px;text-align:center;transition:all .3s ease}.summary-card:hover{box-shadow:0 8px 20px var(--primary-shadow-hover);transform:translateY(-5px) scale(1.02)}.summary-card.success{background:linear-gradient(135deg,var(--success-color) 0,var(--success-hover) 100%);box-shadow:0 4px 12px var(--success-color-alpha-02)}.summary-card.success:hover{box-shadow:0 8px 20px var(--success-color-alpha-02)}.summary-card.error{background:linear-gradient(135deg,var(--error-color) 0,var(--error-hover) 100%);box-shadow:0 4px 12px var(--error-color-alpha-02)}.summary-card.error:hover{box-shadow:0 8px 20px var(--error-color-alpha-02)}.card-value{font-size:36px;font-weight:800;letter-spacing:-1px;margin-bottom:8px;text-shadow:0 2px 4px var(--card-shadow-sm)}.card-label{font-size:13px;opacity:.9}.results-table-container{border:1px solid var(--border-color);border-radius:8px}.results-table thead{background:var(--bg-secondary)}.results-table th{border-bottom:2px solid var(--border-color);color:var(--text-secondary);cursor:pointer;font-size:13px;padding:12px 16px;-webkit-user-select:none;user-select:none}.results-table th:hover{background:#edf2f7}.results-table td{border-bottom:1px solid #e2e8f0;font-size:14px;padding:12px 16px}.results-table tbody tr:hover{background:var(--bg-secondary)}.status-badge{align-items:center;border-radius:12px;display:inline-flex;font-size:12px;gap:4px;padding:4px 10px}.status-badge.success{background:var(--success-light);color:var(--success-hover)}.status-badge.error{background:var(--error-light);color:var(--error-hover)}.positive{color:var(--success-color)}.negative{color:var(--error-color)}.expand-btn{background:var(--bg-tertiary);border:none;border-radius:6px;font-size:12px;gap:4px;padding:6px 12px}.expand-btn:hover{background:var(--border-color-dark)}.expanded-details{background:var(--bg-secondary);border-top:2px solid var(--border-color);padding:24px}.expanded-details h4{color:var(--text-primary);margin:0 0 16px}.metrics-grid{grid-gap:16px;gap:16px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:20px}.metric-item{align-items:center;background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;display:flex;justify-content:space-between;padding:12px}.metric-label{color:var(--text-tertiary);font-size:13px}.metric-value{font-size:14px;font-weight:600}.buy-hold-comparison{background:var(--card-bg);border:2px solid var(--border-color);border-radius:8px;margin-top:20px;padding:16px}.buy-hold-comparison h5{color:var(--text-primary);margin:0 0 12px}.comparison-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.comparison-item{background:var(--bg-secondary);border-radius:6px;display:flex;flex-direction:column;gap:4px;padding:12px}.comparison-item span{color:var(--text-tertiary);font-size:12px}.comparison-item strong{font-size:16px}.leaderboard-view h3{color:var(--text-primary);font-size:24px;margin:0 0 24px}.leaderboard-section{margin-bottom:32px}.leaderboard-section h4{color:var(--text-secondary);font-size:18px;margin:0 0 16px}.leaderboard-table{border-collapse:collapse;border-radius:8px;box-shadow:0 2px 4px var(--card-shadow-sm);overflow:hidden;width:100%}.leaderboard-table thead{background:var(--info-color);color:var(--text-inverse)}.leaderboard-table th{font-size:13px;font-weight:600;padding:12px 16px}.leaderboard-table td{border-bottom:1px solid #e2e8f0;font-size:14px;padding:12px 16px}.leaderboard-table tbody tr{background:var(--card-bg)}.leaderboard-table tbody tr:hover{background:var(--bg-secondary)}.leaderboard-table .rank-1{background:linear-gradient(90deg,var(--warning-color) 0,var(--warning-light) 100%)}.leaderboard-table .rank-2{background:linear-gradient(90deg,var(--text-tertiary) 0,var(--bg-secondary) 100%)}.leaderboard-table .rank-3{background:linear-gradient(90deg,var(--warning-hover) 0,var(--warning-light) 100%)}.rank-cell{font-size:16px}.message-cell{max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media (max-width:768px){.config-inputs,.indicator-grid,.ticker-grid{grid-template-columns:1fr}.action-buttons{flex-direction:column}.action-buttons button{width:100%}.summary-cards{grid-template-columns:repeat(2,1fr)}.results-table-container{font-size:12px}.results-table td,.results-table th{padding:8px}.metrics-grid{grid-template-columns:1fr}}.custom-chart-container{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;margin-bottom:20px;overflow:hidden;padding:16px;position:relative;width:100%}.custom-chart-container:hover{overscroll-behavior:contain}.custom-chart-title{border-bottom:2px solid #f0f0f0;color:#333;font-size:16px;font-weight:600;margin-bottom:12px;padding-bottom:8px}.custom-chart-canvas{border-radius:4px;display:block;overscroll-behavior:contain;touch-action:none;width:100%}.custom-chart-controls{align-items:center;border-top:1px solid #f0f0f0;display:flex;gap:12px;justify-content:flex-end;margin-top:12px;padding-top:12px}.chart-control-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:12px;font-weight:500;padding:6px 16px;transition:all .2s ease}.chart-control-btn:hover{box-shadow:0 4px 8px #667eea4d;transform:translateY(-1px)}.chart-control-btn:active{transform:translateY(0)}.chart-zoom-level{color:#666;font-size:12px;font-weight:500}.custom-chart-container.dark{background:#1a1d29}.custom-chart-container.dark .custom-chart-title{border-bottom-color:#2b2b43;color:#d1d4dc}.custom-chart-container.dark .custom-chart-controls{border-top-color:#2b2b43}.custom-chart-container.dark .chart-zoom-level{color:#d1d4dc}.custom-chart-container.loading{opacity:.6;pointer-events:none}.custom-chart-container.loading:after{animation:spin 1s linear infinite;border:4px solid #f3f3f3;border-radius:50%;border-top-color:#667eea;content:"";height:40px;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);width:40px}@media (max-width:768px){.custom-chart-container{padding:12px}.custom-chart-title{font-size:14px}.custom-chart-controls{gap:8px}.chart-control-btn{font-size:11px;padding:4px 12px}}.chart-with-toggle{position:relative}.chart-type-toggle{display:flex;gap:8px;margin-bottom:12px}.toggle-btn{align-items:center;background:#f5f5f5;border:2px solid #0000;border-radius:6px;color:#666;cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:6px;padding:8px 16px;transition:all .2s ease}.toggle-btn:hover{background:#ebebeb;color:#333}.toggle-btn.active{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea;box-shadow:0 2px 8px #667eea4d;color:#fff}.toggle-btn svg{flex-shrink:0}.chart-with-toggle.dark .toggle-btn{background:#2b2b43;color:#d1d4dc}.chart-with-toggle.dark .toggle-btn:hover{background:#3a3a55}.chart-with-toggle.dark .toggle-btn.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}@media (max-width:768px){.toggle-btn{font-size:12px;padding:6px 12px}.toggle-btn span{display:none}}.enhanced-candlestick-chart{margin:20px 0;width:100%}.enhanced-candlestick-chart .chart-container{border-radius:8px;box-shadow:0 2px 8px #0000001a;height:100%;overflow:hidden;width:100%}.enhanced-candlestick-chart .volume-container{border-radius:8px;box-shadow:0 2px 8px #0000001a;height:150px;margin-top:10px;overflow:hidden;width:100%}.equity-curve-chart{background:var(--card-bg);border-radius:12px;box-shadow:0 2px 8px var(--card-shadow-md);margin:24px 0;padding:24px}.equity-curve-chart h3{color:var(--text-primary);font-size:20px;font-weight:600;margin:0 0 20px}.equity-curve-chart .chart-wrapper{margin-bottom:20px}.equity-curve-chart .custom-tooltip{background:var(--card-bg-alpha-095);border:1px solid var(--border-color-light);border-radius:8px;box-shadow:0 2px 8px var(--card-shadow-md);padding:12px}.equity-curve-chart .custom-tooltip .label{color:var(--text-primary);font-size:13px;font-weight:600;margin:0 0 8px}.equity-curve-chart .custom-tooltip p{font-size:12px;margin:4px 0}.equity-summary{grid-gap:16px;border-top:1px solid var(--border-color);display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));padding-top:20px}.equity-summary .summary-item{display:flex;flex-direction:column;gap:6px}.equity-summary .summary-item .label{color:var(--text-tertiary);font-size:13px;font-weight:500}.equity-summary .summary-item .value{color:var(--text-primary);font-size:18px;font-weight:700}.equity-summary .summary-item .value.success{color:var(--success-color)}.equity-summary .summary-item .value.danger{color:var(--error-color)}@media (max-width:768px){.equity-summary{grid-template-columns:1fr}.equity-curve-chart{padding:16px}}.drawdown-chart{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin:24px 0;padding:24px}.drawdown-chart h3{color:#1a1a1a;font-size:20px;font-weight:600;margin:0 0 20px}.drawdown-chart h4{color:#2d3748;font-size:16px;font-weight:600;margin:24px 0 12px}.drawdown-stats{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:24px}.drawdown-stats .stat-card{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;color:#fff;padding:20px;text-align:center}.drawdown-stats .stat-card.danger{background:linear-gradient(135deg,#f56565,#c53030)}.drawdown-stats .stat-value{font-size:32px;font-weight:700;margin-bottom:8px}.drawdown-stats .stat-label{font-size:13px;margin-bottom:4px;opacity:.9}.drawdown-stats .stat-date{font-size:11px;opacity:.8}.drawdown-chart .chart-wrapper{margin-bottom:24px}.drawdown-tooltip{background:#fffffff2;border:1px solid #ddd;border-radius:8px;box-shadow:0 2px 8px #00000026;padding:12px}.drawdown-tooltip .label{color:#333;font-size:13px;font-weight:600;margin:0 0 8px}.drawdown-tooltip p{color:#666;font-size:12px;margin:4px 0}.drawdown-tooltip .drawdown strong{color:#f44336}.drawdown-periods{border-top:1px solid #e2e8f0;margin-top:24px;padding-top:24px}.drawdown-periods table{border-collapse:collapse;font-size:13px;width:100%}.drawdown-periods thead{background:#f7fafc}.drawdown-periods th{border-bottom:2px solid #e2e8f0;color:#4a5568;font-weight:600;padding:12px;text-align:left}.drawdown-periods td{border-bottom:1px solid #e2e8f0;color:#2d3748;padding:12px}.drawdown-periods td.danger{color:#e53e3e;font-weight:600}.drawdown-periods tbody tr:hover{background:#f7fafc}.no-data{color:#718096;font-size:14px;padding:40px}@media (max-width:768px){.drawdown-stats{grid-template-columns:1fr}.drawdown-chart{padding:16px}.drawdown-periods{overflow-x:auto}}.indicator-panel{background:var(--card-bg);border-radius:12px;box-shadow:0 2px 8px var(--card-shadow-md);margin:16px 0;padding:20px}.indicator-panel h4{color:var(--text-primary);font-size:16px;font-weight:600;margin:0 0 16px}.indicator-panel .current-value{border-top:1px solid var(--border-color);color:var(--text-secondary);font-size:14px;margin-top:12px;padding-top:12px}.indicator-panel .current-value strong{color:var(--text-primary);font-weight:700;margin:0 8px}.indicator-panel .current-value strong.overbought{color:var(--error-color)}.indicator-panel .current-value strong.oversold{color:var(--success-color)}.indicator-panel .current-value strong.neutral{color:var(--info-color)}.indicator-panel .current-value strong.bullish{color:var(--success-color)}.indicator-panel .current-value strong.bearish{color:var(--error-color)}.indicator-panel .signal{border-radius:6px;display:inline-block;font-size:12px;font-weight:600;margin-left:12px;padding:4px 12px}.indicator-panel .signal.buy{background:var(--success-light);color:var(--success-color)}.indicator-panel .signal.sell{background:var(--error-light);color:var(--error-color)}.indicator-panel .signal.neutral{background:var(--bg-tertiary);color:var(--text-primary)}.indicator-panel .signal.strong{background:var(--secondary-light);color:var(--secondary-color)}.indicator-panel .signal.moderate{background:var(--warning-light);color:var(--warning-color)}.indicator-panel .signal.weak{background:var(--bg-tertiary);color:var(--text-secondary)}@media (max-width:768px){.indicator-panel{padding:16px}.indicator-panel h4{font-size:14px}.indicator-panel .current-value{font-size:12px}}.performance-metrics-card{background:var(--card-bg);border-radius:12px;box-shadow:0 2px 8px var(--card-shadow-md);margin:24px 0;padding:24px}.performance-metrics-card .metrics-title{color:var(--text-primary);font-size:20px;font-weight:600;margin:0 0 24px}.performance-metrics-card .metrics-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:24px}.performance-metrics-card .metric-item{align-items:flex-start;background:var(--gradient-primary);border-radius:12px;color:var(--text-inverse);display:flex;gap:16px;padding:20px;transition:transform .2s,box-shadow .2s}.performance-metrics-card .metric-item:hover{box-shadow:0 4px 12px var(--card-shadow-lg);transform:translateY(-2px)}.performance-metrics-card .metric-item.positive{background:linear-gradient(135deg,var(--success-color) 0,var(--success-hover) 100%)}.performance-metrics-card .metric-item.negative{background:linear-gradient(135deg,var(--error-color) 0,var(--error-hover) 100%)}.performance-metrics-card .metric-item.neutral{background:linear-gradient(135deg,var(--info-color) 0,var(--info-hover) 100%)}.performance-metrics-card .metric-icon{flex-shrink:0;opacity:.9}.performance-metrics-card .metric-content{flex:1 1}.performance-metrics-card .metric-label{font-size:13px;margin-bottom:8px;opacity:.9}.performance-metrics-card .metric-value{font-size:28px;font-weight:700;margin-bottom:4px}.performance-metrics-card .metric-subvalue{font-size:12px;opacity:.85}.performance-metrics-card .additional-metrics{background:var(--bg-secondary);border-radius:8px;margin-bottom:24px;padding:20px}.performance-metrics-card .metric-row{align-items:center;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:10px 0}.performance-metrics-card .metric-row:last-child{border-bottom:none}.performance-metrics-card .metric-row .label{color:var(--text-secondary);font-size:14px;font-weight:500}.performance-metrics-card .metric-row .value{color:var(--text-primary);font-size:16px;font-weight:700}.performance-metrics-card .metric-row .value.positive{color:var(--success-color)}.performance-metrics-card .metric-row .value.negative{color:var(--error-color)}.performance-metrics-card .buy-hold-comparison{background:linear-gradient(135deg,var(--bg-tertiary) 0,var(--border-color) 100%);border-radius:8px;padding:20px}.performance-metrics-card .buy-hold-comparison h4{color:var(--text-primary);font-size:16px;font-weight:600;margin:0 0 16px}.performance-metrics-card .comparison-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));margin-bottom:16px}.performance-metrics-card .comparison-item{background:var(--card-bg);border-radius:8px;padding:16px;text-align:center}.performance-metrics-card .comparison-label{color:var(--text-tertiary);font-size:12px;margin-bottom:8px}.performance-metrics-card .comparison-value{font-size:20px;font-weight:700}.performance-metrics-card .comparison-value.positive{color:var(--success-color)}.performance-metrics-card .comparison-value.negative{color:var(--error-color)}.performance-metrics-card .comparison-value.neutral{color:var(--info-color)}.performance-metrics-card .comparison-summary{background:var(--card-bg);border-radius:8px;font-weight:600;padding:12px;text-align:center}.performance-metrics-card .comparison-summary .success{color:var(--success-color)}.performance-metrics-card .comparison-summary .warning{color:var(--warning-color)}.no-metrics{color:var(--text-tertiary);font-size:14px;padding:40px;text-align:center}@media (max-width:768px){.performance-metrics-card{padding:16px}.performance-metrics-card .metrics-grid{gap:12px;grid-template-columns:1fr}.performance-metrics-card .metric-value{font-size:22px}.performance-metrics-card .comparison-grid{grid-template-columns:1fr}}.candlestick-showcase{background:var(--card-bg);border-radius:12px;box-shadow:0 2px 8px var(--card-shadow-md);margin:24px 0;padding:24px}.candlestick-showcase .showcase-header{margin-bottom:24px}.candlestick-showcase .showcase-header h3{color:var(--text-primary);font-size:20px;font-weight:600;margin:0 0 8px}.candlestick-showcase .showcase-header p{color:var(--text-tertiary);font-size:14px;margin:0}.pattern-statistics{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));margin-bottom:24px}.pattern-statistics .stat-card{border-radius:12px;color:#fff;padding:20px;text-align:center}.pattern-statistics .stat-card.total{background:var(--gradient-primary)}.pattern-statistics .stat-card.bullish{background:linear-gradient(135deg,var(--success-color) 0,var(--success-hover) 100%)}.pattern-statistics .stat-card.bearish{background:linear-gradient(135deg,var(--error-color) 0,var(--error-hover) 100%)}.pattern-statistics .stat-card.neutral{background:linear-gradient(135deg,var(--info-color) 0,var(--info-hover) 100%)}.pattern-statistics .stat-value{font-size:32px;font-weight:700;margin-bottom:8px}.pattern-statistics .stat-label{font-size:13px;opacity:.9}.most-common-patterns{background:var(--bg-secondary);border-radius:8px;margin-bottom:24px;padding:20px}.most-common-patterns h4{color:var(--text-primary);font-size:16px;font-weight:600;margin:0 0 16px}.common-patterns-list{display:flex;flex-direction:column;gap:12px}.common-pattern-item{align-items:center;background:var(--card-bg);border-left:4px solid var(--primary-color);border-radius:6px;display:flex;justify-content:space-between;padding:12px}.common-pattern-item .pattern-name{color:var(--text-primary);font-weight:600}.common-pattern-item .pattern-count{color:var(--text-tertiary);font-size:13px}.showcase-controls{align-items:center;background:var(--bg-secondary);border-radius:8px;display:flex;flex-wrap:wrap;gap:20px;margin-bottom:24px;padding:16px}.showcase-controls .filter-group{align-items:center;display:flex;gap:8px}.showcase-controls .filter-group label{color:var(--text-secondary);font-size:14px;font-weight:500}.showcase-controls .filter-group select{background:var(--card-bg);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);font-size:14px;padding:6px 12px}.showcase-controls .results-count{color:var(--text-tertiary);font-size:14px;font-weight:500;margin-left:auto}.pattern-timeline{margin-bottom:24px}.pattern-timeline h4{color:var(--text-primary);font-size:16px;font-weight:600;margin:0 0 16px}.timeline-list{display:flex;flex-direction:column;gap:12px;max-height:600px;overflow-y:auto}.timeline-item{background:var(--bg-secondary);border:2px solid #0000;border-radius:8px;cursor:pointer;display:flex;gap:16px;padding:16px;transition:all .2s}.timeline-item:hover{background:var(--bg-tertiary);transform:translateX(4px)}.timeline-item.selected{background:var(--success-light);border-color:var(--primary-color)}.timeline-item.bullish .timeline-marker{background:var(--success-light);color:var(--success-hover)}.timeline-item.bearish .timeline-marker{background:var(--error-light);color:var(--error-hover)}.timeline-item.neutral .timeline-marker{background:#e2e8f0;color:var(--text-primary)}.timeline-marker{align-items:center;border-radius:8px;display:flex;flex-shrink:0;height:40px;justify-content:center;width:40px}.timeline-content{flex:1 1}.timeline-header{align-items:center;margin-bottom:8px}.timeline-header .pattern-name{color:var(--text-primary);font-size:15px;font-weight:600}.timeline-header .pattern-date{color:var(--text-tertiary);font-size:13px}.timeline-details{display:flex;flex-wrap:wrap;gap:12px}.timeline-details .pattern-type{border-radius:4px;font-size:11px;font-weight:700;padding:4px 10px;text-transform:uppercase}.timeline-details .pattern-type.bullish{background:#c6f6d5;color:#22543d}.timeline-details .pattern-type.bearish{background:#fed7d7;color:#742a2a}.timeline-details .pattern-type.neutral{background:#e2e8f0;color:var(--text-primary)}.timeline-details .pattern-confidence,.timeline-details .pattern-strength{color:var(--text-tertiary);font-size:12px}.pattern-detail-panel{background:var(--card-bg);border-radius:12px;box-shadow:0 20px 60px var(--card-shadow-lg);left:50%;max-height:80vh;max-width:600px;overflow-y:auto;position:fixed;top:50%;transform:translate(-50%,-50%);width:90%;z-index:1000}.pattern-detail-panel:before{background:var(--overlay-dark);bottom:0;content:"";left:0;position:fixed;right:0;top:0;z-index:-1}.pattern-detail-panel .panel-header{align-items:center;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;padding:20px}.pattern-detail-panel .panel-header h4{color:var(--text-primary);font-size:18px;font-weight:600;margin:0}.pattern-detail-panel .panel-actions{align-items:center;display:flex;gap:8px}.pattern-detail-panel .view-chart-btn{align-items:center;background:var(--gradient-primary);border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:13px;font-weight:600;gap:6px;padding:8px 16px;transition:all .2s}.pattern-detail-panel .view-chart-btn:hover{box-shadow:0 4px 12px var(--primary-shadow-hover);transform:translateY(-1px)}.pattern-detail-panel .close-btn{align-items:center;background:none;border:none;border-radius:6px;color:var(--text-tertiary);cursor:pointer;display:flex;font-size:28px;height:32px;justify-content:center;padding:0;transition:all .2s;width:32px}.pattern-detail-panel .close-btn:hover{background:var(--bg-secondary);color:var(--text-primary)}.pattern-detail-panel .panel-content{padding:20px}.pattern-detail-panel .detail-row{align-items:center;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;padding:12px 0}.pattern-detail-panel .detail-label{color:var(--text-secondary);font-size:14px;font-weight:600}.pattern-detail-panel .detail-value{align-items:center;color:var(--text-primary);display:flex;font-size:14px;gap:8px}.pattern-detail-panel .detail-value.bullish{color:#38a169}.pattern-detail-panel .detail-value.bearish{color:#e53e3e}.pattern-detail-panel .detail-value.neutral{color:#4299e1}.pattern-detail-panel .detail-section{margin-top:20px}.pattern-detail-panel .detail-section h5{color:var(--text-primary);font-size:15px;font-weight:600;margin:0 0 12px}.pattern-detail-panel .detail-section p{color:var(--text-secondary);font-size:14px;line-height:1.6;margin:0}.pattern-detail-panel .reliability{background:var(--primary-color);border-radius:6px;color:var(--text-inverse);display:inline-block;font-weight:600;padding:6px 14px}.pattern-chart-section{border-top:2px solid var(--border-color);margin-top:24px;padding-top:24px}.pattern-chart-section h5{color:var(--text-primary);font-size:16px;font-weight:600;margin:0 0 8px}.pattern-chart-section .chart-description{color:var(--text-tertiary);font-size:13px;margin:0 0 16px}.pattern-chart-container{background:var(--bg-secondary);border-radius:8px;min-height:400px;overflow:hidden;padding:16px;width:100%}.pattern-chart-container .no-chart-data{color:var(--text-tertiary);font-size:14px;padding:40px;text-align:center}.no-patterns{color:var(--text-tertiary);padding:60px 20px}.no-patterns svg{margin-bottom:16px;opacity:.5}.no-patterns p{font-size:14px;margin:0}.type-icon{display:inline-block}.type-icon.bullish{color:#38a169}.type-icon.bearish{color:#e53e3e}.type-icon.neutral{color:#4299e1}@media (max-width:768px){.candlestick-showcase{padding:16px}.pattern-statistics{grid-template-columns:1fr 1fr}.showcase-controls{align-items:stretch;flex-direction:column}.showcase-controls .results-count{margin-left:0;margin-top:12px}.pattern-detail-panel{max-height:90vh;width:95%}}.fibonacci-analysis{background:var(--card-bg);border-radius:12px;box-shadow:0 2px 8px var(--card-shadow-md);margin:24px 0;padding:24px}.fibonacci-analysis .fib-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:24px}.fibonacci-analysis .fib-header h3{color:var(--text-primary);font-size:20px;font-weight:600;margin:0}.fibonacci-analysis .fib-controls{display:flex;gap:16px}.fibonacci-analysis .toggle-label{align-items:center;color:var(--text-secondary);cursor:pointer;display:flex;font-size:14px;gap:8px}.fibonacci-analysis .toggle-label input[type=checkbox]{cursor:pointer;height:18px;width:18px}.current-price-info{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:24px}.current-price-info .info-card{background:var(--gradient-primary);border-radius:12px;color:var(--text-inverse);padding:20px;text-align:center}.current-price-info .info-label{font-size:13px;margin-bottom:8px;opacity:.9}.current-price-info .info-value{align-items:center;display:flex;font-size:24px;font-weight:700;gap:8px;justify-content:center}.current-price-info .info-value.uptrend{color:var(--success-light)}.current-price-info .info-value.downtrend{color:var(--error-light)}.fib-signals{background:var(--bg-secondary);border-radius:8px;margin-bottom:24px;padding:20px}.fib-signals h4{align-items:center;color:var(--text-primary);display:flex;font-size:16px;font-weight:600;gap:8px;margin:0 0 16px}.signals-list{display:flex;flex-direction:column;gap:12px}.signal-item{align-items:center;background:var(--card-bg);border-left:4px solid;border-radius:8px;display:flex;gap:12px;padding:12px 16px}.signal-item.bullish{background:var(--success-light);border-left-color:var(--success-color)}.signal-item.bearish{background:var(--error-light);border-left-color:var(--error-color)}.signal-item.important{background:var(--warning-light);border-left-color:var(--warning-color)}.signal-item.info,.signal-item.warning{background:var(--info-light);border-left-color:var(--info-color)}.signal-item .signal-icon{flex-shrink:0;font-size:20px}.signal-item .signal-message{color:var(--text-primary);font-size:14px}.fib-chart{margin-bottom:24px}.fib-chart h4{color:var(--text-primary);font-size:16px;font-weight:600;margin:0 0 16px}.fib-levels-table{margin-bottom:24px}.fib-levels-table h4{color:var(--text-primary);font-size:16px;font-weight:600;margin:0 0 16px}.fib-levels-table table{border-collapse:collapse;font-size:14px;width:100%}.fib-levels-table thead{background:var(--bg-secondary)}.fib-levels-table th{border-bottom:2px solid var(--border-color);color:var(--text-secondary);font-weight:600;padding:12px;text-align:left}.fib-levels-table td{border-bottom:1px solid var(--border-color);color:var(--text-primary);padding:12px}.fib-levels-table tr:hover{background:var(--bg-secondary)}.fib-levels-table tr.closest{background:var(--error-light);font-weight:600}.fib-levels-table .level-name{color:var(--secondary-color);font-weight:600}.fib-levels-table .level-price{font-family:Courier New,monospace}.fib-levels-table .level-desc{color:var(--text-tertiary);font-size:13px}.fib-levels-table .importance-badge{border-radius:4px;display:inline-block;font-size:11px;font-weight:700;padding:4px 10px;text-transform:uppercase}.fib-levels-table .importance-badge.high{background:var(--error-light);color:var(--error-color)}.fib-levels-table .importance-badge.medium{background:var(--warning-light);color:var(--warning-color)}.fib-levels-table .importance-badge.low{background:var(--bg-tertiary);color:var(--text-primary)}.fib-levels-table .level-distance{font-weight:600}.fib-levels-table .level-distance.above{color:var(--success-color)}.fib-levels-table .level-distance.below{color:var(--error-color)}.fib-guide{background:linear-gradient(135deg,var(--bg-tertiary) 0,var(--border-color) 100%);border-radius:8px;padding:20px}.fib-guide h4{color:var(--text-primary);font-size:16px;font-weight:600;margin:0 0 16px}.fib-guide .guide-content{display:flex;flex-direction:column;gap:12px}.fib-guide .guide-item{background:var(--card-bg);border-radius:6px;color:var(--text-secondary);font-size:14px;line-height:1.6;padding:12px}.fib-guide .guide-item strong{color:var(--text-primary)}.no-data{color:var(--text-tertiary)}.no-data svg{margin-bottom:16px;opacity:.5}@media (max-width:768px){.fibonacci-analysis{padding:16px}.current-price-info{grid-template-columns:1fr 1fr}.fib-levels-table{overflow-x:auto}.fib-header{align-items:flex-start;flex-direction:column;gap:16px}}.export-panel-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:var(--overlay-dark);bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:2000}.export-panel{background:var(--card-bg);border-radius:16px;box-shadow:0 20px 60px var(--card-shadow-lg);display:flex;flex-direction:column;max-height:90vh;max-width:700px;overflow:hidden;width:100%}.export-header{align-items:center;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:24px}.export-header h3{color:var(--text-primary);font-size:22px;font-weight:700;margin:0}.export-header .close-btn{align-items:center;background:none;border:none;border-radius:8px;color:var(--text-tertiary);cursor:pointer;display:flex;justify-content:center;padding:8px;transition:all .2s}.export-header .close-btn:hover{background:var(--bg-secondary);color:var(--text-primary)}.export-status{border-radius:8px;font-size:14px;font-weight:500;margin:16px 24px;padding:12px 16px}.export-status.success{background:var(--success-light);border-left:4px solid var(--success-color);color:var(--success-color)}.export-status.error{background:var(--error-light);border-left:4px solid var(--error-color);color:var(--error-color)}.export-status.info{background:var(--info-light);border-left:4px solid var(--info-color);color:var(--info-color)}.export-content{flex:1 1;overflow-y:auto;padding:24px}.export-section{margin-bottom:28px}.export-section:last-child{margin-bottom:0}.export-section h4{color:var(--text-primary);font-size:16px;font-weight:600;margin:0 0 12px}.export-options{display:flex;flex-direction:column;gap:8px}.export-btn{background:var(--gradient-primary);border-radius:10px;box-shadow:0 4px 12px var(--primary-shadow-hover);color:var(--text-inverse);font-size:15px;font-weight:600;gap:12px;padding:14px 20px;transition:all .3s}.export-btn:hover:not(:disabled){box-shadow:0 6px 16px var(--primary-shadow-hover);transform:translateY(-2px)}.export-btn:active:not(:disabled){transform:translateY(0)}.export-btn:disabled{opacity:.5}.export-btn.secondary{background:linear-gradient(135deg,var(--text-tertiary) 0,var(--text-secondary) 100%);box-shadow:0 4px 12px var(--card-shadow-md)}.export-btn.secondary:hover:not(:disabled){box-shadow:0 6px 16px var(--card-shadow-md)}.export-desc{color:var(--text-tertiary);font-size:13px;margin:0;padding-left:4px}.export-footer{background:var(--bg-secondary);border-top:1px solid var(--border-color);padding:16px 24px}.export-note{align-items:center;color:var(--text-secondary);display:flex;font-size:13px;gap:8px;margin:0}.export-content::-webkit-scrollbar{width:8px}.export-content::-webkit-scrollbar-track{background:var(--bg-tertiary);border-radius:4px}.export-content::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}.export-content::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}@media print{.dashboard-sidebar,.export-btn,.export-panel-overlay,.mode-switcher,.tabs,button{display:none!important}.dashboard-main{max-width:100%!important;width:100%!important}.backtest-content,.chart-section,.indicator-panel{page-break-inside:avoid}body{-webkit-print-color-adjust:exact;print-color-adjust:exact}}@media (max-width:768px){.export-panel{border-radius:0;max-height:100vh;max-width:100%}.export-header{padding:16px}.export-header h3{font-size:18px}.export-content{padding:16px}.export-section{margin-bottom:20px}.export-btn{font-size:14px;padding:12px 16px}}.technical-dashboard{background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;padding:24px;position:relative}.technical-dashboard:before{background:radial-gradient(circle at 20% 50%,#ffffff1a 0,#0000 50%),radial-gradient(circle at 80% 80%,#ffffff1a 0,#0000 50%);content:"";height:100%;left:0;pointer-events:none;position:fixed;top:0;width:100%;z-index:0}.technical-dashboard>*{position:relative;z-index:1}.combined-chart-section{background:#fff;border-radius:12px;box-shadow:0 4px 12px #0000001a;margin-bottom:24px;padding:24px}.combined-chart-section h4{color:#1f2937;font-size:18px;font-weight:600;margin:0 0 16px}.individual-indicator-chart{background:#fff;border-radius:12px;box-shadow:0 4px 12px #0000001a;margin-bottom:24px;padding:24px}.individual-indicator-chart h4{color:#1f2937;font-size:16px;font-weight:600;margin:0 0 16px}.candlestick-patterns-section{background:#fff;border-radius:12px;box-shadow:0 4px 12px #0000001a;margin-top:24px;padding:24px}.candlestick-patterns-section h4{color:#1f2937;font-size:18px;font-weight:600;margin:0 0 20px}.patterns-list{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(400px,1fr))}.pattern-item{background:#f9fafb;border-left:4px solid #e5e7eb;transition:all .3s ease}.pattern-item.bullish{background:#f1f8f4;border-left-color:#4caf50}.pattern-item.bearish{background:#fef5f5;border-left-color:#f44336}.pattern-item.neutral{background:#fff8f0;border-left-color:#ff9800}.pattern-item:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.pattern-item-header{margin-bottom:12px}.pattern-info h5{color:#1f2937;font-size:16px;font-weight:600;margin:0 0 8px}.pattern-meta{align-items:center;flex-wrap:wrap;gap:12px}.pattern-type-badge{border-radius:4px;font-size:11px;font-weight:700;padding:4px 12px;text-transform:uppercase}.pattern-type-badge.bullish{background:#c6f6d5;color:#22543d}.pattern-type-badge.bearish{background:#fed7d7;color:#742a2a}.pattern-type-badge.neutral{background:#feebc8;color:#7c2d12}.pattern-date{font-size:13px}.pattern-chart-mini{background:#fff;border-radius:6px;margin:12px 0;padding:12px}.pattern-ohlc{border-top:1px solid #e5e7eb;color:#6b7280;display:flex;font-size:12px;gap:16px;margin-top:12px;padding-top:12px}.pattern-ohlc span{font-weight:600}.checkbox-group{display:flex;flex-direction:column;gap:8px;margin-top:8px}.checkbox-group label{align-items:center;color:#4a5568;cursor:pointer;display:flex;font-size:13px;gap:8px}.checkbox-group input[type=checkbox]{cursor:pointer}.mode-switcher-container{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff;border:1px solid #fffc;border-radius:20px;box-shadow:0 10px 30px #0000001f;margin-bottom:32px;padding:32px}.mode-switcher-header{margin-bottom:28px;text-align:center}.mode-switcher-header h2{color:#1f2937;font-size:1.75rem;font-weight:700;letter-spacing:-.5px;margin-bottom:8px}.mode-switcher-header p{color:#6b7280;font-size:1rem;font-weight:400}.mode-switcher{display:flex;flex-wrap:wrap;gap:20px;justify-content:center}.mode-btn{align-items:center;background:#fff;border:3px solid #e5e7eb;border-radius:16px;box-shadow:0 4px 12px #00000014;color:#6b7280;cursor:pointer;display:flex;font-size:15px;font-weight:600;gap:16px;min-width:320px;padding:24px 40px;transition:all .3s cubic-bezier(.4,0,.2,1)}.mode-btn:hover{background:linear-gradient(135deg,#f9fafb,#fff);border-color:#667eea;box-shadow:0 8px 20px #667eea33;color:#667eea;transform:translateY(-3px)}.mode-btn.active{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#0000;box-shadow:0 8px 25px #667eea80;color:#fff;transform:scale(1.02)}.mode-btn.active:hover{box-shadow:0 8px 24px #667eea80;transform:translateY(-3px) scale(1.02)}.mode-btn-content{align-items:flex-start;display:flex;flex:1 1;flex-direction:column;gap:6px}.mode-btn-title{font-size:17px;font-weight:700;letter-spacing:-.2px;line-height:1.3}.mode-btn-desc{font-size:13px;font-weight:400;line-height:1.4;opacity:.85}.dashboard-header{border-radius:16px;box-shadow:0 8px 20px #0000001a;margin-bottom:24px;padding:32px}.export-fab{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:10px;box-shadow:0 4px 12px #667eea4d;color:#fff;cursor:pointer;display:flex;font-size:15px;font-weight:600;gap:8px;padding:12px 24px;transition:all .3s}.export-fab:hover{box-shadow:0 6px 16px #667eea66;transform:translateY(-2px)}.export-fab:active{transform:translateY(0)}.header-content h1{align-items:center;color:#1f2937;display:flex;font-size:2rem;gap:12px;margin-bottom:8px}.header-content p{color:#6b7280;font-size:1.1rem;margin-left:44px}.dashboard-container{grid-gap:24px;display:grid;gap:24px;grid-template-columns:350px 1fr;margin:0 auto;max-width:1600px}.control-panel{background:#fff;border-radius:16px;box-shadow:0 4px 12px #0000001a;height:-webkit-fit-content;height:fit-content;padding:24px;position:-webkit-sticky;position:sticky;top:20px}.control-section{border-bottom:2px solid #e5e7eb;margin-bottom:20px;padding-bottom:20px}.control-section:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.control-section h3{align-items:center;color:#1f2937;display:flex;font-size:1.1rem;font-weight:600;gap:8px;margin-bottom:16px}.stock-select{border:2px solid #e5e7eb;border-radius:8px;font-size:.95rem;padding:12px;transition:all .2s ease}.date-inputs{gap:12px}.date-input-group,.date-inputs{display:flex;flex-direction:column}.date-input-group{gap:6px}.date-input-group label{color:#4b5563;font-size:.9rem;font-weight:600}.date-input-group input{border:2px solid #e5e7eb;border-radius:8px;font-size:.95rem;padding:10px 12px;transition:all .2s ease}.date-input-group input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.indicators-list{display:flex;flex-direction:column;gap:8px}.indicator-item{border-radius:8px;overflow:hidden;transition:all .2s ease}.indicator-checkbox-label{align-items:flex-start;background:#f9fafb;cursor:pointer;display:flex;gap:10px;padding:12px;transition:all .2s ease}.indicator-checkbox-label:hover{background:#f3f4f6}.indicator-checkbox-label input[type=checkbox]{accent-color:#667eea;cursor:pointer;height:18px;margin-top:3px;width:18px}.indicator-info{flex:1 1;flex-direction:column;gap:4px}.indicator-name{font-size:.95rem}.indicator-desc{color:#6b7280;font-size:.85rem;line-height:1.4}.indicator-params{background:#fff;border-top:1px solid #e5e7eb}.params-toggle{align-items:center;background:#f9fafb;border:none;color:#667eea;cursor:pointer;display:flex;font-size:.85rem;font-weight:600;gap:6px;padding:10px 12px;transition:all .2s ease;width:100%}.params-toggle:hover{background:#f3f4f6}.params-content{background:#fff;padding:12px}.templates{margin-bottom:12px}.templates label{color:#374151;display:block;font-size:.9rem;font-weight:600;margin-bottom:8px}.template-buttons{display:flex;flex-wrap:wrap;gap:6px}.template-btn{background:#fff;border:2px solid #667eea;border-radius:6px;color:#667eea;font-size:.85rem;font-weight:600;padding:6px 12px;transition:all .2s ease}.custom-params{display:flex;flex-direction:column;gap:8px}.custom-params>label{color:#374151;font-size:.9rem;font-weight:600;margin-bottom:4px}.param-input{align-items:center;gap:8px}.param-input label{font-size:.85rem;min-width:80px}.param-input input,.param-input select{border:2px solid #e5e7eb;border-radius:6px;flex:1 1;font-size:.9rem;padding:6px 10px;transition:border-color .2s ease}.param-input input:focus,.param-input select:focus{border-color:#667eea;outline:none}.btn{border-radius:12px;font-size:1rem;gap:10px;justify-content:center;margin-bottom:12px;padding:14px 20px;transition:all .3s ease;width:100%}.btn:disabled{opacity:.5}.btn-primary:hover:not(:disabled){box-shadow:0 6px 20px #667eea66}.btn-secondary{background:#10b981}.btn-secondary:hover:not(:disabled){background:#059669;box-shadow:0 6px 20px #10b98166;transform:translateY(-2px)}.results-section{background:#fff;border-radius:16px;box-shadow:0 4px 12px #0000001a;min-height:600px;padding:32px}.tabs{gap:8px;margin-bottom:32px}.tab{background:none;font-size:1rem;font-weight:600;padding:14px 24px;transition:all .2s ease}.tab:hover:not(:disabled){background:#f9fafb;color:#667eea}.tab.active{background:#f0f4ff}.tab:disabled{cursor:not-allowed;opacity:.5}.tab-content{animation:fadeIn .3s ease}.tab-content h2{border-bottom:2px solid #e5e7eb;color:#1f2937;font-size:1.8rem;margin-bottom:24px;padding-bottom:16px}.overview-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:32px}.overview-card{background:linear-gradient(135deg,#f9fafb,#fff);border:2px solid #e5e7eb;border-radius:12px;padding:24px;transition:all .3s ease}.overview-card:hover{border-color:#667eea;box-shadow:0 6px 20px #667eea26;transform:translateY(-2px)}.overview-card h3{color:#6b7280;font-size:.9rem;font-weight:600;letter-spacing:.5px;margin-bottom:12px;text-transform:uppercase}.value-large{color:#1f2937;font-size:2.5rem;font-weight:700;margin-bottom:8px}.overview-card p{color:#9ca3af;font-size:.9rem}.summary-section{background:#f9fafb;border-radius:12px;margin-top:32px;padding:24px}.summary-section h3{color:#1f2937;font-size:1.3rem;margin-bottom:20px}.summary-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.summary-item{justify-content:space-between;padding:12px}.summary-item strong{color:#4b5563;font-weight:600}.summary-item span{color:#1f2937;font-weight:600}.chart-container{background:#f9fafb;border-radius:12px;margin-bottom:32px;padding:24px}.chart-container h3{border-bottom:2px solid #e5e7eb;color:#1f2937;font-size:1.3rem;margin-bottom:20px;padding-bottom:12px}.result-card{background:#f9fafb;border-left:4px solid #667eea;border-radius:12px;margin-bottom:24px;padding:24px}.result-card h3{color:#1f2937;font-size:1.3rem;margin-bottom:8px}.param-info{color:#6b7280;font-size:.9rem;margin-bottom:20px}.indicator-stats{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.stat{align-items:center;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000000d;display:flex;justify-content:space-between;padding:16px}.stat span{color:#6b7280;font-size:.9rem;font-weight:600}.stat strong{color:#1f2937;font-size:1.1rem;font-weight:700}.patterns-list{display:flex;flex-direction:column;gap:12px}.pattern-item{background:#fff;border-left:4px solid;border-radius:8px;box-shadow:0 2px 4px #0000000d;padding:16px}.pattern-item.bullish{border-left-color:#10b981}.pattern-item.bearish{border-left-color:#ef4444}.pattern-item.neutral{border-left-color:#f59e0b}.pattern-header{margin-bottom:8px}.pattern-header strong{color:#1f2937;font-size:1.1rem}.pattern-badge{border-radius:12px;font-size:.85rem;font-weight:600;padding:4px 12px;text-transform:uppercase}.pattern-badge.bullish{background:#d1fae5;color:#065f46}.pattern-badge.bearish{background:#fee2e2;color:#991b1b}.pattern-badge.neutral{background:#fef3c7;color:#92400e}.pattern-item p{color:#6b7280;line-height:1.5;margin:8px 0}.pattern-date{color:#9ca3af}.no-patterns{padding:40px 20px}.metrics-grid{grid-gap:20px;gap:20px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-bottom:32px}.metric-card{background:linear-gradient(135deg,#f9fafb,#fff);border:2px solid #e5e7eb;border-radius:12px;display:flex;gap:16px;padding:24px;transition:all .3s ease}.metric-card:hover{border-color:#667eea;box-shadow:0 6px 20px #667eea26}.metric-icon{align-items:center;background:#f3f4f6;border-radius:12px;color:#6b7280;display:flex;height:56px;justify-content:center;width:56px}.metric-icon.success{background:#d1fae5;color:#10b981}.metric-icon.danger{background:#fee2e2;color:#ef4444}.metric-content{display:flex;flex:1 1;flex-direction:column;gap:6px}.metric-label{color:#6b7280;font-size:.9rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.metric-value{color:#1f2937;font-size:1.8rem}.trades-table-wrapper{border-radius:8px;box-shadow:0 2px 4px #0000000d;margin-top:20px;overflow-x:auto}.trades-table{background:#fff;border-collapse:collapse;font-size:.9rem;width:100%}.trades-table thead{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.trades-table th{font-size:.85rem;font-weight:600;letter-spacing:.5px;padding:14px 12px;text-align:left;text-transform:uppercase}.trades-table td{border-bottom:1px solid #e5e7eb;color:#1f2937;padding:14px 12px}.trades-table tbody tr:hover{background:#f9fafb}.trades-table tbody tr:last-child td{border-bottom:none}.trade-type{border-radius:12px;display:inline-block;font-size:.85rem;font-weight:600;padding:6px 12px}.trade-type.buy{background:#d1fae5;color:#065f46}.trade-type.sell{background:#fee2e2;color:#991b1b}.positive{color:#10b981!important;font-weight:600}.negative{color:#ef4444!important;font-weight:600}.signal-cell{color:#6b7280;font-size:.85rem;max-width:200px;overflow:hidden;text-overflow:ellipsis}@media (max-width:1200px){.dashboard-container{grid-template-columns:1fr}.control-panel{position:static}}@media (max-width:768px){.dashboard-header{padding:20px}.header-content h1{font-size:1.5rem}.header-content p{font-size:.95rem;margin-left:0;margin-top:8px}.results-section{padding:20px}.indicator-stats,.metrics-grid,.overview-grid,.summary-grid{grid-template-columns:1fr}.tabs{flex-wrap:nowrap;overflow-x:auto}.tab{font-size:.9rem;padding:12px 16px;white-space:nowrap}.value-large{font-size:2rem}.metric-value{font-size:1.5rem}.trades-table{font-size:.8rem}.trades-table td,.trades-table th{padding:10px 8px}.chart-container{padding:16px}}@media (max-width:480px){.dashboard-header{padding:16px}.header-content h1{font-size:1.3rem}.control-panel,.results-section{padding:16px}.tab-content h2{font-size:1.5rem}}.loading{align-items:center;color:#6b7280;display:flex;font-size:1.1rem;justify-content:center;padding:40px}.error{background:#fee2e2;border-radius:8px;color:#991b1b;margin-bottom:20px;padding:16px}.sub-tabs{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:24px}.sub-tab{background:#fff;border:2px solid #e5e7eb;border-radius:8px;color:#6b7280;cursor:pointer;font-size:.9rem;font-weight:600;padding:10px 16px;transition:all .2s ease}.sub-tab:hover{border-color:#667eea;color:#667eea}.sub-tab.active{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea;color:#fff}.chart-stats{grid-gap:16px;background:#fff;border:2px solid #e5e7eb;border-radius:8px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-top:20px;padding:20px}.backtest-config{gap:12px}.backtest-config,.config-item{display:flex;flex-direction:column}.config-item{gap:6px}.config-item label{color:#4b5563;font-size:.9rem;font-weight:600}.config-item input,.config-item select{border:2px solid #e5e7eb;border-radius:6px;font-size:.9rem;padding:8px 12px}.config-item input:focus,.config-item select:focus{border-color:#667eea;outline:none}.patterns-preview{background:#f9fafb;border-radius:12px;margin-top:32px;padding:24px}.patterns-preview h3{color:#1f2937;font-size:1.3rem;margin-bottom:20px}.patterns-grid{grid-gap:16px;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.pattern-card{border-left:4px solid;border-radius:8px;box-shadow:0 2px 4px #0000000d;padding:16px;transition:all .3s ease}.pattern-card.bullish{border-left-color:#10b981}.pattern-card.bearish{border-left-color:#ef4444}.pattern-card.neutral{border-left-color:#f59e0b}.pattern-visual{display:flex;justify-content:center;margin-bottom:12px}.candlestick-svg{display:block}.pattern-info{text-align:center}.pattern-info strong{color:#1f2937;display:block;font-size:1rem;margin-bottom:8px}.pattern-info .badge{border-radius:12px;display:inline-block;font-size:.8rem;font-weight:600;margin-bottom:8px;padding:4px 10px;text-transform:uppercase}.pattern-info .badge.bullish{background:#d1fae5;color:#065f46}.pattern-info .badge.bearish{background:#fee2e2;color:#991b1b}.pattern-info .badge.neutral{background:#fef3c7;color:#92400e}.pattern-info p{color:#9ca3af;font-size:.85rem;margin-top:8px}.pattern-item-detail{background:#fff;border-left:4px solid;border-radius:8px;box-shadow:0 2px 4px #0000000d;display:flex;gap:16px;margin-bottom:12px;padding:16px;transition:all .2s ease}.pattern-item-detail:hover{box-shadow:0 4px 12px #0000001a}.pattern-item-detail.bullish{border-left-color:#10b981}.pattern-item-detail.bearish{border-left-color:#ef4444}.pattern-item-detail.neutral{border-left-color:#f59e0b}.pattern-visual-container{align-items:center;background:#f9fafb;border-radius:8px;display:flex;flex-shrink:0;height:80px;justify-content:center;width:100px}.pattern-content{flex:1 1}.pattern-description{color:#6b7280;font-size:.95rem;line-height:1.5;margin:8px 0}.pattern-meta{display:flex;gap:16px;margin-top:8px}.pattern-meta span{align-items:center;color:#9ca3af;display:flex;font-size:.85rem;gap:4px}.pattern-index{font-weight:600}.table-info{color:#6b7280;font-size:.95rem;margin-bottom:16px}.data-table-wrapper{border-radius:8px;box-shadow:0 2px 8px #0000000d;margin-top:20px;max-height:600px;overflow-x:auto;overflow-y:auto}.data-table{background:#fff;font-size:.85rem}.data-table thead{position:-webkit-sticky;position:sticky;top:0;z-index:10}.data-table th{font-size:.75rem;letter-spacing:.5px;text-transform:uppercase}.data-table td{border-bottom:1px solid #e5e7eb;color:#1f2937;white-space:nowrap}.data-table tbody tr:hover{background:#f9fafb}.data-table tbody tr:last-child td{border-bottom:none}.tabs .tab{align-items:center;display:flex;gap:6px}::-webkit-scrollbar{height:8px;width:8px}::-webkit-scrollbar-track{background:#f1f5f9;border-radius:4px}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}.ohlc-chart-section{margin-top:2rem}.chart-controls{margin-bottom:1rem}.view-selector{background:#f3f4f6;border-radius:8px;display:flex;gap:.5rem;padding:4px}.view-selector button{background:#0000;border:none;border-radius:6px;color:#6b7280;cursor:pointer;font-weight:500;padding:8px 16px;transition:all .2s}.view-selector button.active{background:#fff;box-shadow:0 2px 4px #0000001a;color:#667eea}.view-selector button:hover{color:#667eea}.export-btn{gap:8px;padding:8px 16px;transition:all .2s}.export-btn:hover{box-shadow:0 4px 8px #667eea4d;transform:translateY(-1px)}.raw-data-table{margin-top:3rem}.raw-data-table h4{color:#1f2937;font-size:1.3rem;margin-bottom:1rem}.table-wrapper{background:#fff;border-radius:8px;max-height:500px}.table-wrapper table{border-collapse:collapse;font-size:.9rem;width:100%}.table-wrapper thead{background:#f9fafb;position:-webkit-sticky;position:sticky;top:0;z-index:10}.table-wrapper th{border-bottom:2px solid #e5e7eb;color:#374151;font-weight:600;padding:12px 16px;text-align:left;white-space:nowrap}.table-wrapper td{border-bottom:1px solid #f3f4f6;color:#6b7280;padding:12px 16px}.table-wrapper tbody tr:hover{background:#f9fafb}.table-wrapper td.positive{color:#10b981;font-weight:600}.table-wrapper td.negative{color:#ef4444;font-weight:600}.summary-stats-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-top:2rem}.stat-card{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 4px 12px #667eea33;flex-direction:column;gap:.5rem}.stat-card .stat-label{color:#ffffffe6;font-size:.9rem;font-weight:500}.stat-card .stat-value{color:#fff;font-size:1.8rem;font-weight:700}.signal-table-container{margin:2rem 0}.signal-summary{background:#f9fafb;border-radius:12px;margin-bottom:1.5rem;padding:1.5rem}.signal-summary h4{color:#1f2937;font-size:1.2rem;margin-bottom:1rem}.summary-stats{grid-gap:1rem;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.stat-item{align-items:center;background:#fff;border-left:4px solid #6b7280;border-radius:8px;justify-content:space-between;padding:.75rem 1rem}.stat-item.buy{border-left-color:#10b981}.stat-item.sell{border-left-color:#ef4444}.stat-item.neutral{border-left-color:#6b7280}.stat-item .label{color:#6b7280;font-size:.9rem;font-weight:500}.stat-item .value{color:#1f2937;font-size:1.1rem;font-weight:700}.stat-item.buy .value{color:#10b981}.stat-item.sell .value{color:#ef4444}.signal-table-wrapper{overflow-x:auto}.signal-table{background:#fff;border-collapse:collapse;border-radius:8px;box-shadow:0 2px 8px #0000000d;overflow:hidden;width:100%}.signal-table thead{background:#f9fafb}.signal-table th{border-bottom:2px solid #e5e7eb;color:#374151;font-size:.9rem;font-weight:600;padding:12px 16px;text-align:left}.signal-table td{border-bottom:1px solid #f3f4f6;color:#6b7280;font-size:.9rem;padding:12px 16px}.signal-table tbody tr{transition:background .2s}.signal-table tbody tr:hover{background:#f9fafb}.signal-table tbody tr.buy{background:#10b9810d}.signal-table tbody tr.sell{background:#ef44440d}.signal-badge{border-radius:6px;font-size:.85rem;gap:4px;padding:4px 12px}.signal-badge .signal-icon{height:16px;width:16px}.signal-badge .signal-icon.buy{color:#10b981}.signal-badge .signal-icon.sell{color:#ef4444}.signal-badge .signal-icon.neutral{color:#6b7280}.indicator-badge{background:#f3f4f6;color:#667eea;display:inline-block;font-weight:600;padding:4px 10px}.description-cell{color:#4b5563;line-height:1.5;max-width:400px}.indicator-detail-section{background:#fff;border-radius:12px;box-shadow:0 2px 12px #0000000d;margin:3rem 0;padding:2rem}.indicator-detail-section h3{align-items:center;color:#1f2937;display:flex;font-size:1.5rem;gap:.5rem;margin-bottom:1.5rem}.indicator-detail-section h4{border-top:2px solid #f3f4f6;color:#374151;font-size:1.2rem;margin:2rem 0 1rem;padding-top:2rem}.signal-section{margin-bottom:2rem}.calculation-table{margin-top:2rem}.status-badge{border-radius:6px;display:inline-block;font-size:.85rem;font-weight:600;padding:4px 12px}.status-badge.neutral{background:#f3f4f6;color:#6b7280}.status-badge.overbought{background:#fef2f2;color:#ef4444}.status-badge.oversold{background:#f0fdf4;color:#10b981}.crossover-badge{border-radius:6px;display:inline-block;font-size:.85rem;font-weight:600;padding:4px 12px}.crossover-badge.bullish{background:#f0fdf4;color:#10b981}.crossover-badge.bearish{background:#fef2f2;color:#ef4444}.position-badge{border-radius:6px;display:inline-block;font-size:.85rem;font-weight:600;padding:4px 12px}.position-badge.above-upper{background:#fef2f2;color:#ef4444}.position-badge.below-lower{background:#f0fdf4;color:#10b981}.position-badge.upper-half{background:#fef3c7;color:#f59e0b}.position-badge.lower-half{background:#dbeafe;color:#3b82f6}.position-badge.neutral{background:#f3f4f6;color:#6b7280}.trend-badge{border-radius:6px;display:inline-block;font-size:.85rem;font-weight:600;padding:4px 12px}.trend-badge.bullish{background:#f0fdf4;color:#10b981}.trend-badge.bearish{background:#fef2f2;color:#ef4444}.trend-badge.neutral{background:#f3f4f6;color:#6b7280}.low-badge,.spike-badge{border-radius:6px;display:inline-block;font-size:.85rem;font-weight:600;padding:4px 12px}.spike-badge{background:#fef2f2;color:#ef4444}.low-badge{background:#f3f4f6;color:#6b7280}.table-wrapper td.spike{color:#ef4444;font-weight:600}.table-wrapper td.low{color:#6b7280}.interpretation-cell{color:#6b7280;font-size:.85rem;line-height:1.4;max-width:300px}.chart-section{border-radius:12px;box-shadow:0 2px 12px #0000000d;margin:2rem 0}.chart-header{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:1.5rem}.chart-header h3{color:#1f2937;font-size:1.5rem;margin:0}.chart-legend{gap:1rem}.legend-item{color:#6b7280}.legend-color{border-radius:3px;display:inline-block}.chart-section h3{color:#1f2937;margin-bottom:1rem}.chart-section h4{color:#374151;font-size:1.1rem;margin:1.5rem 0 .5rem}.chart-section .indicator-desc{color:#6b7280;font-size:.95rem;margin-bottom:1.5rem}.individual-chart{margin-top:2rem}.combined-chart{border:2px solid #667eea;border-radius:12px}.chart-container{margin:1rem 0}.fibonacci-overview-section{background:#fff;border:2px solid #e5e7eb;border-radius:16px;box-shadow:0 6px 20px #00000014;margin:24px 0;padding:28px;transition:all .3s ease}.fibonacci-overview-section:hover{border-color:#667eea;box-shadow:0 8px 30px #667eea26}.fibonacci-info{grid-gap:2rem;align-items:start;display:grid;gap:2rem;grid-template-columns:300px 1fr}.fib-levels table{font-size:.9rem;width:100%}.fib-levels table td,.fib-levels table th{padding:8px 12px;text-align:left}.fib-levels table th{background:#f9fafb;color:#374151;font-weight:600}.fib-levels table td{border-top:1px solid #f3f4f6;color:#6b7280}.candlestick-patterns,.patterns-grid{margin-top:1rem}.patterns-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.pattern-card{background:#fff;border:2px solid #e5e7eb;border-radius:12px}.pattern-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.pattern-card.bullish{background:#10b98105;border-color:#10b981}.pattern-card.bearish{background:#ef444405;border-color:#ef4444}.pattern-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.75rem}.pattern-name{color:#1f2937;font-size:1rem;font-weight:700}.pattern-type{border-radius:6px;font-size:.75rem;font-weight:600;padding:4px 10px}.pattern-type.bullish{background:#f0fdf4;color:#10b981}.pattern-type.bearish{background:#fef2f2;color:#ef4444}.pattern-details{display:flex;flex-direction:column;gap:.5rem}.pattern-date{color:#6b7280;font-size:.85rem;font-weight:500}.pattern-description{color:#4b5563;font-size:.9rem;line-height:1.4}.no-patterns{color:#6b7280;font-style:italic;padding:2rem;text-align:center}.dashboard-layout{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:350px 1fr;margin:0 auto;max-width:1600px}.dashboard-sidebar{border-radius:16px;box-shadow:0 4px 12px #0000001a;height:-webkit-fit-content;height:fit-content;max-height:calc(100vh - 40px);overflow-x:hidden;overflow-y:auto;padding:2rem;position:-webkit-sticky;position:sticky;scroll-behavior:smooth;top:20px}.dashboard-sidebar::-webkit-scrollbar{width:8px}.dashboard-sidebar::-webkit-scrollbar-track{background:#f1f5f9;border-radius:4px}.dashboard-sidebar::-webkit-scrollbar-thumb{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:4px;-webkit-transition:background .3s;transition:background .3s}.dashboard-sidebar::-webkit-scrollbar-thumb:hover{background:linear-gradient(135deg,#5568d3,#6b3fa2)}.dashboard-main{background:#fff;border-radius:16px;box-shadow:0 4px 12px #0000001a}.tabs{background:#f9fafb;border-bottom:2px solid #e5e7eb}.tab{flex:1 1;gap:8px;justify-content:center}.tab.active{background:#fff}.tab-content{min-height:600px}.overview-content{position:relative}.overview-header h3{color:#1f2937}.backtest-content,.charts-content,.indicators-content{position:relative}.backtest-placeholder{align-items:center;color:#6b7280;display:flex;flex-direction:column;gap:1rem;justify-content:center;padding:4rem 2rem}.backtest-placeholder p{font-size:1.1rem;max-width:500px;text-align:center}.loading-overlay{border-radius:12px}.loading-overlay p{font-size:1.1rem}@media (max-width:1200px){.dashboard-layout{grid-template-columns:1fr}.dashboard-sidebar{position:static}.fibonacci-info{grid-template-columns:1fr}}.combined-signals-enhanced{background:#fff;border-radius:12px;box-shadow:0 2px 12px #0000000d;margin:2rem 0;padding:2rem}.combined-signals-header{align-items:flex-start;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:1.5rem}.combined-signals-header h3{color:#1f2937;font-size:1.5rem;margin:0}.signal-summary{display:flex;flex-wrap:wrap;gap:1.5rem}.summary-item{flex-direction:column;gap:.25rem}.summary-label{font-size:.75rem}.summary-value{font-size:1.1rem}.summary-value.bullish{color:#10b981}.summary-value.bearish{color:#ef4444}.indicator-agreement-matrix{background:#f9fafb;border-radius:8px;margin:1.5rem 0;padding:1.5rem}.indicator-agreement-matrix h4{color:#374151;font-size:1.1rem;margin-bottom:1rem}.matrix-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}.matrix-item{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:1rem}.matrix-indicator-name{color:#374151;font-size:.9rem;font-weight:600;margin-bottom:.5rem}.matrix-stats{display:flex;font-size:.85rem;gap:.75rem}.matrix-bullish{color:#10b981;font-weight:600}.matrix-bearish{color:#ef4444;font-weight:600}.technical-overview-section{background:#fff;border-radius:12px;box-shadow:0 2px 12px #0000000d;margin:2rem 0;padding:2rem}.technical-overview-section h3{color:#1f2937;font-size:1.5rem;margin-bottom:1.5rem}.technical-overview-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.overview-card{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:1.5rem}.overview-card h4{color:#374151;font-size:1.1rem;font-weight:600;margin-bottom:1rem}.signal-status-content{align-items:center;display:flex;justify-content:center;min-height:120px}.signal-badge-large{align-items:center;border-radius:12px;display:flex;flex-direction:column;gap:.75rem;min-width:150px;padding:1.5rem;text-align:center}.signal-badge-large.bullish{background:#10b9811a;border:2px solid #10b981}.signal-badge-large.bearish{background:#ef44441a;border:2px solid #ef4444}.signal-badge-large.neutral{background:#6b72801a;border:2px solid #6b7280}.signal-icon{align-items:center;display:flex;justify-content:center}.signal-text{font-size:1.25rem;font-weight:700;text-transform:uppercase}.signal-date{color:#6b7280;font-size:.75rem}.indicators-summary-list{display:flex;flex-direction:column;gap:.75rem}.indicator-summary-item{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:6px;display:flex;justify-content:space-between;padding:.75rem}.indicator-summary-name{align-items:center;color:#374151;display:flex;font-weight:500;gap:.5rem}.indicator-summary-status{align-items:center;display:flex;gap:.75rem}.signal-badge-small{border-radius:6px;font-size:.75rem;font-weight:600;padding:.25rem .75rem;text-transform:uppercase}.signal-badge-small.bullish{background:#10b9811a;color:#10b981}.signal-badge-small.bearish{background:#ef44441a;color:#ef4444}.signal-badge-small.neutral{background:#6b72801a;color:#6b7280}.indicator-value{color:#6b7280;font-size:.875rem;font-weight:600}.combination-logic-content{display:flex;flex-direction:column;gap:1rem}.logic-badge{border:2px solid;border-radius:8px;display:flex;flex-direction:column;gap:.5rem;padding:1rem}.logic-badge.or-logic{background:#ef44440d;border-color:#ef4444}.logic-badge.and-logic{background:#10b9810d;border-color:#10b981}.logic-icon{color:#1f2937;font-size:1.5rem;font-weight:700}.logic-desc{color:#6b7280;font-size:.875rem}.logic-stats{display:flex;flex-direction:column;gap:.5rem}.logic-stat-item{background:#fff;border-radius:6px;display:flex;justify-content:space-between;padding:.5rem}.logic-stat-label{color:#6b7280;font-size:.875rem}.logic-stat-value{color:#1f2937;font-weight:600}.pattern-summary-content{display:flex;flex-direction:column;gap:1rem}.pattern-count{align-items:center;background:#fff;border-radius:8px;display:flex;flex-direction:column;padding:1rem}.pattern-count-number{color:#667eea;font-size:2rem;font-weight:700}.pattern-count-label{color:#6b7280;font-size:.875rem}.pattern-breakdown{display:flex;gap:1rem;justify-content:space-around}.pattern-type-count{align-items:center;display:flex;flex-direction:column;gap:.25rem}.pattern-type-label{color:#6b7280;font-size:.75rem}.pattern-type-value{font-size:1.25rem;font-weight:700}.pattern-type-value.bullish{color:#10b981}.pattern-type-value.bearish{color:#ef4444}@media (max-width:768px){.summary-stats-grid{grid-template-columns:1fr}.tabs{flex-wrap:nowrap;overflow-x:auto}.tab{flex:0 0 auto;min-width:150px}.matrix-grid,.technical-overview-grid{grid-template-columns:1fr}}.adx-chart,.bollinger-bands-chart,.macd-chart,.rsi-chart,.stochastic-chart,.volume-chart{margin-bottom:20px}.chart-legend{align-items:center;background:#f9f9f9;border-radius:6px;display:flex;flex-wrap:wrap;gap:20px;margin-top:12px;padding:12px}.legend-item{color:#666;font-size:12px;gap:8px}.legend-color{height:3px}.legend-line{border-top:2px dashed;height:0;width:20px}.no-indicator-data{padding:40px 20px}.volume-chart canvas{border-radius:4px;display:block;width:100%}.macd-chart{position:relative}.macd-histogram-overlay{pointer-events:none}.dark .chart-legend{background:#2b2b43}.dark .legend-item{color:#d1d4dc}.dark .no-indicator-data{background:#2b2b43;color:#999}@media (max-width:768px){.chart-legend{gap:12px;padding:8px}.legend-item{font-size:11px}.legend-color{width:12px}.legend-line{width:16px}}.combined-chart-view{width:100%}.main-chart-container{margin-bottom:20px}.indicator-charts-stack{display:flex;flex-direction:column;gap:16px}.stacked-chart{width:100%}.ticker-data-table{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;margin-top:30px;padding:20px}.table-header{border-bottom:2px solid #f0f0f0;margin-bottom:16px;padding-bottom:12px}.table-header h3{color:#333;font-size:18px;margin:0 0 6px}.table-subtitle{color:#666;font-size:13px;margin:0}.table-container{margin-bottom:16px}.data-table{border-collapse:collapse;font-size:13px;width:100%}.data-table thead{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.data-table th{font-weight:600;padding:12px 10px;position:-webkit-sticky;position:sticky;text-align:left;top:0;white-space:nowrap;z-index:10}.data-table tbody tr{border-bottom:1px solid #f0f0f0;transition:background-color .2s ease}.data-table tbody tr:hover{background-color:#f9f9f9}.data-table tbody tr:last-child{border-bottom:none}.data-table td{color:#333;padding:10px}.table-pagination{align-items:center;border-top:1px solid #f0f0f0;display:flex;gap:16px;justify-content:center;padding-top:16px}.pagination-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:13px;font-weight:500;padding:8px 16px;transition:all .2s ease}.pagination-btn:hover:not(:disabled){box-shadow:0 4px 8px #667eea4d;transform:translateY(-1px)}.pagination-btn:disabled{cursor:not-allowed;opacity:.5}.pagination-info{color:#666;font-size:13px;font-weight:500}.no-data{background:#f9f9f9;border-radius:8px;color:#999;padding:60px 20px}.no-data p{font-size:14px;margin:0}.dark .ticker-data-table{background:#1a1d29}.dark .table-header{border-bottom-color:#2b2b43}.dark .table-header h3{color:#d1d4dc}.dark .table-header .table-subtitle{color:#999}.dark .data-table tbody tr{border-bottom-color:#2b2b43}.dark .data-table tbody tr:hover{background-color:#2b2b43}.dark .data-table td,.dark .pagination-info{color:#d1d4dc}.dark .no-data{background:#2b2b43}@media (max-width:768px){.ticker-data-table{padding:16px}.table-header h3{font-size:16px}.table-subtitle{font-size:12px}.data-table{font-size:11px}.data-table td,.data-table th{padding:8px 6px}.pagination-btn{font-size:12px;padding:6px 12px}.pagination-info{font-size:12px}}.individual-chart-card{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;margin-bottom:20px;padding:20px}.individual-chart-card h3{color:#333;font-size:16px;font-weight:600;margin:0 0 16px}.dark .individual-chart-card{background:#1a1d29}.dark .individual-chart-card h3{color:#d1d4dc}.calculation-table-wrapper{margin-top:20px;width:100%}.calculation-table{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:20px}.calculation-table h4{border-bottom:2px solid #f0f0f0;color:#333;font-size:16px;font-weight:600;margin:0 0 15px;padding-bottom:10px}.calculation-table table{border-collapse:collapse;width:100%}.calculation-table thead{background:#f8f9fa}.calculation-table th{border-bottom:2px solid #e0e0e0;color:#666;font-size:13px;font-weight:600;padding:12px;text-align:left}.calculation-table td{border-bottom:1px solid #f0f0f0;color:#333;font-size:14px;padding:10px 12px}.calculation-table tbody tr:last-child td{border-bottom:none}.calculation-table tbody tr:hover{background:#f8f9fa}.calculation-table .signal{border-radius:4px;display:inline-block;font-weight:600;padding:4px 12px}.calculation-table .signal.bullish,.calculation-table .signal.buy{background:#e8f5e9;color:#2e7d32}.calculation-table .signal.bearish,.calculation-table .signal.sell{background:#ffebee;color:#c62828}.calculation-table .signal.neutral{background:#f5f5f5;color:#666}.calculation-table .bullish,.calculation-table .value.bullish,.calculation-table .value.buy{color:#2e7d32;font-weight:600}.calculation-table .bearish,.calculation-table .value.bearish,.calculation-table .value.sell{color:#c62828;font-weight:600}.calculation-table .overbought{color:#ff6b6b;font-weight:600}.calculation-table .oversold{color:#51cf66;font-weight:600}.calculation-table .strong-trend{color:#667eea;font-weight:600}.calculation-table .weak-trend{color:#999}.calculation-table .high-volume{color:#ff9800;font-weight:600}.calculation-table .high-volatility{color:#ff6b6b;font-weight:600}.calculation-table .low-volatility{color:#51cf66}.calculation-table .above{color:#2e7d32}.calculation-table .below{color:#c62828}.calculation-table .above-vwap{color:#2e7d32;font-weight:600}.calculation-table .below-vwap{color:#c62828;font-weight:600}.calculation-table .section-header{background:#f0f0f0;font-weight:600;text-align:center}.calculation-table .closest-level{background:#fff9c4;font-weight:600}.calculation-table .current-price-row{background:#e3f2fd;font-weight:600}.no-indicator-data{background:#f9f9f9;border:2px dashed #e0e0e0;border-radius:8px;color:#999;padding:40px;text-align:center}.no-indicator-data p{font-size:14px;margin:0}@media (max-width:768px){.calculation-table{overflow-x:auto;padding:15px}.calculation-table table{min-width:500px}.calculation-table td,.calculation-table th{font-size:12px;padding:8px}.calculation-table h4{font-size:14px}}.full-data-table{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;margin-top:30px;padding:20px}.full-data-table .table-header{align-items:center;border-bottom:2px solid #f0f0f0;display:flex;justify-content:space-between;margin-bottom:20px;padding-bottom:15px}.full-data-table .table-header h4{color:#333;font-size:16px;font-weight:600;margin:0}.full-data-table .toggle-btn{background:#667eea;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:13px;font-weight:500;padding:8px 16px;transition:all .3s ease}.full-data-table .toggle-btn:hover{background:#5568d3;box-shadow:0 2px 8px #667eea4d;transform:translateY(-1px)}.full-data-table .table-wrapper{border:1px solid #e0e0e0;border-radius:6px;max-height:600px;overflow-x:auto;overflow-y:auto}.full-data-table table{border-collapse:collapse;min-width:800px;width:100%}.full-data-table thead{background:#f8f9fa;box-shadow:0 2px 4px #0000000d;position:-webkit-sticky;position:sticky;top:0;z-index:10}.full-data-table th{border-bottom:2px solid #e0e0e0;color:#666;font-size:13px;font-weight:600;padding:12px;text-align:left;white-space:nowrap}.full-data-table th.sortable{cursor:pointer;transition:background .2s ease;-webkit-user-select:none;user-select:none}.full-data-table th.sortable:hover{background:#e9ecef}.full-data-table .sort-icon{color:#667eea;font-size:10px;margin-left:4px}.full-data-table td{border-bottom:1px solid #f0f0f0;color:#333;font-size:13px;padding:10px 12px}.full-data-table tbody tr:hover{background:#f8f9fa}.full-data-table tbody tr:last-child td{border-bottom:none}.full-data-table .signal-buy{background:#e8f5e9;color:#2e7d32}.full-data-table .signal-buy,.full-data-table .signal-sell{border-radius:4px;font-weight:600;padding:4px 8px;text-align:center}.full-data-table .signal-sell{background:#ffebee;color:#c62828}.full-data-table .signal-neutral{background:#f5f5f5;border-radius:4px;color:#666;font-weight:600;padding:4px 8px;text-align:center}.full-data-table .trend-cell{color:#555;font-weight:500}.full-data-table .table-footer{color:#666;font-size:13px;margin-top:15px;text-align:right}.full-data-table .table-footer p{margin:0}@media (max-width:768px){.full-data-table{padding:15px}.full-data-table .table-header{align-items:flex-start;flex-direction:column;gap:10px}.full-data-table .toggle-btn{width:100%}.full-data-table td,.full-data-table th{font-size:12px;padding:8px}}.candlestick-pattern-view{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;margin-top:20px;padding:24px}.candlestick-pattern-view .pattern-header{border-bottom:2px solid #f0f0f0;margin-bottom:24px;padding-bottom:16px}.candlestick-pattern-view .pattern-header h3{color:#333;font-size:20px;margin:0 0 8px}.candlestick-pattern-view .pattern-header p{color:#666;font-size:14px;margin:0}.candlestick-pattern-view .pattern-stats{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:24px}.candlestick-pattern-view .stat-card{border-radius:8px;padding:20px;text-align:center}.candlestick-pattern-view .stat-card.bullish{background:linear-gradient(135deg,#e8f5e9,#c8e6c9);border:2px solid #81c784}.candlestick-pattern-view .stat-card.bearish{background:linear-gradient(135deg,#ffebee,#ffcdd2);border:2px solid #e57373}.candlestick-pattern-view .stat-card.neutral{background:linear-gradient(135deg,#f5f5f5,#e0e0e0);border:2px solid #bdbdbd}.candlestick-pattern-view .stat-number{font-size:32px;font-weight:700;margin-bottom:8px}.candlestick-pattern-view .stat-label{color:#666;font-size:13px;font-weight:500}.candlestick-pattern-view .filter-buttons{display:flex;gap:12px;margin-bottom:24px}.candlestick-pattern-view .filter-buttons button{background:#fff;border:2px solid #e0e0e0;border-radius:6px;cursor:pointer;flex:1 1;font-size:14px;font-weight:500;padding:10px 20px;transition:all .3s ease}.candlestick-pattern-view .filter-buttons button:hover{background:#f8f9ff;border-color:#667eea}.candlestick-pattern-view .filter-buttons button.active{background:#667eea;border-color:#667eea;color:#fff}.candlestick-pattern-view .pattern-chart-container{border:1px solid #e0e0e0;border-radius:8px;margin-bottom:24px;padding:16px}.candlestick-pattern-view .patterns-table-container{border:1px solid #e0e0e0;border-radius:8px;margin-bottom:24px;overflow-x:auto}.candlestick-pattern-view .patterns-table{border-collapse:collapse;width:100%}.candlestick-pattern-view .patterns-table thead{background:#f8f9fa}.candlestick-pattern-view .patterns-table th{border-bottom:2px solid #e0e0e0;color:#666;font-size:13px;font-weight:600;padding:12px;text-align:left}.candlestick-pattern-view .patterns-table td{border-bottom:1px solid #f0f0f0;font-size:14px;padding:12px}.candlestick-pattern-view .patterns-table tbody tr{cursor:pointer;transition:background .2s ease}.candlestick-pattern-view .patterns-table tbody tr:hover{background:#f8f9fa}.candlestick-pattern-view .patterns-table tbody tr.selected{background:#e3f2fd}.candlestick-pattern-view .pattern-badge{border-radius:4px;display:inline-block;font-size:13px;font-weight:600;padding:4px 12px}.candlestick-pattern-view .pattern-badge.bullish{background:#e8f5e9;color:#2e7d32}.candlestick-pattern-view .pattern-badge.bearish{background:#ffebee;color:#c62828}.candlestick-pattern-view .pattern-badge.neutral{background:#f5f5f5;color:#666}.candlestick-pattern-view .type-badge{border-radius:3px;display:inline-block;font-size:11px;font-weight:600;padding:2px 8px}.candlestick-pattern-view .type-badge.bullish{background:#2e7d32;color:#fff}.candlestick-pattern-view .type-badge.bearish{background:#c62828;color:#fff}.candlestick-pattern-view .type-badge.neutral{background:#666;color:#fff}.candlestick-pattern-view .detail-btn{background:#667eea;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:12px;font-weight:500;padding:6px 12px;transition:all .2s ease}.candlestick-pattern-view .detail-btn:hover{background:#5568d3;transform:translateY(-1px)}.candlestick-pattern-view .pattern-detail-modal{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.candlestick-pattern-view .modal-content{background:#fff;border-radius:12px;max-height:80vh;max-width:600px;overflow-y:auto;padding:32px;position:relative;width:90%}.candlestick-pattern-view .close-btn{background:none;border:none;color:#999;cursor:pointer;font-size:32px;height:32px;line-height:1;padding:0;position:absolute;right:16px;top:16px;width:32px}.candlestick-pattern-view .close-btn:hover{color:#333}.candlestick-pattern-view .detail-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(2,1fr);margin:24px 0}.candlestick-pattern-view .detail-item{display:flex;flex-direction:column;gap:4px}.candlestick-pattern-view .detail-item label{color:#666;font-size:12px;font-weight:600;text-transform:uppercase}.candlestick-pattern-view .detail-item span{color:#333;font-size:14px}.candlestick-pattern-view .detail-section{background:#f8f9fa;border-radius:8px;margin:24px 0;padding:16px}.candlestick-pattern-view .detail-section h4{color:#333;font-size:14px;margin:0 0 12px}.candlestick-pattern-view .detail-section p{color:#666;line-height:1.6;margin:0}.candlestick-pattern-view .action-text{color:#667eea;font-weight:500}.candlestick-pattern-view .candle-data-table{border-collapse:collapse;width:100%}.candlestick-pattern-view .candle-data-table td,.candlestick-pattern-view .candle-data-table th{border:1px solid #e0e0e0;padding:8px;text-align:left}.candlestick-pattern-view .candle-data-table th{background:#fff;color:#666;font-size:12px;font-weight:600}.candlestick-pattern-view .pattern-legend{background:#f8f9fa;border-radius:8px;padding:16px}.candlestick-pattern-view .pattern-legend h4{color:#333;font-size:14px;margin:0 0 12px}.candlestick-pattern-view .legend-items{display:flex;flex-direction:column;gap:8px}.candlestick-pattern-view .legend-item{align-items:center;color:#666;display:flex;font-size:13px;gap:8px}.candlestick-pattern-view .legend-dot{border-radius:50%;height:12px;width:12px}.candlestick-pattern-view .legend-dot.very-high{background:#2e7d32}.candlestick-pattern-view .legend-dot.high{background:#43a047}.candlestick-pattern-view .legend-dot.medium{background:#ffa726}.candlestick-pattern-view .error-state,.candlestick-pattern-view .loading-state,.candlestick-pattern-view .no-patterns{color:#666;padding:40px;text-align:center}.candlestick-pattern-view .spinner{animation:spin 1s linear infinite;border:4px solid #f0f0f0;border-radius:50%;border-top-color:#667eea;height:40px;margin:0 auto 16px;width:40px}.candlestick-pattern-view .retry-btn{background:#667eea;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;margin-top:16px;padding:8px 16px}@media (max-width:768px){.candlestick-pattern-view{padding:16px}.candlestick-pattern-view .pattern-stats{grid-template-columns:1fr}.candlestick-pattern-view .filter-buttons{flex-direction:column}.candlestick-pattern-view .detail-grid{grid-template-columns:1fr}.candlestick-pattern-view .modal-content{padding:24px;width:95%}}.all-combinations-view{padding:20px}.combinations-header{align-items:center;border-bottom:2px solid #f0f0f0;display:flex;justify-content:space-between;margin-bottom:24px;padding-bottom:16px}.header-content h2{color:#333;font-size:24px;font-weight:600;margin:0 0 6px}.header-content p{color:#666;font-size:14px;margin:0}.run-analysis-btn{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;padding:12px 24px;transition:all .2s ease}.run-analysis-btn:hover:not(:disabled){box-shadow:0 6px 12px #667eea4d;transform:translateY(-2px)}.run-analysis-btn:disabled{cursor:not-allowed;opacity:.5}.error-message{background:#fee;border:1px solid #fcc;color:#e53e3e;gap:10px;margin-bottom:20px;padding:16px}.loading-state{padding:60px 20px;text-align:center}.spinner{border:4px solid #f3f3f3;border-top-color:#667eea;margin:0 auto 20px}.loading-hint{color:#999;font-size:13px;margin-top:10px}.summary-stats{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:30px}.stat-card{border-radius:12px;box-shadow:0 2px 8px #0000001a;gap:16px;padding:20px}.stat-icon{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;color:#fff;height:50px;width:50px}.stat-value{color:#333;font-size:28px;line-height:1;margin-bottom:4px}.stat-label{color:#666;font-size:13px}.top-combinations-section{margin-bottom:30px}.top-combinations-section h3{color:#333;font-size:20px;font-weight:600;margin:0 0 20px}.combinations-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.combination-card{background:#fff;border:2px solid #f0f0f0;border-radius:12px;cursor:pointer;padding:20px;position:relative;transition:all .2s ease}.combination-card:hover{border-color:#667eea;box-shadow:0 6px 12px #667eea26;transform:translateY(-2px)}.combination-card.selected{background:linear-gradient(135deg,#667eea0d,#764ba20d);border-color:#667eea}.combo-rank{align-items:center;background:linear-gradient(135deg,#ffd93d,orange);border-radius:50%;color:#fff;display:flex;font-size:14px;font-weight:700;height:32px;justify-content:center;position:absolute;right:12px;top:12px;width:32px}.combo-header{align-items:flex-start;display:flex;gap:12px;justify-content:space-between;margin-bottom:12px}.combo-header h4{color:#333;flex:1 1;font-size:16px;font-weight:600;line-height:1.3;margin:0}.combo-rating{border-radius:6px;font-size:12px;font-weight:600;padding:4px 10px;white-space:nowrap}.combo-score{color:#667eea;font-size:14px;font-weight:600;margin-bottom:12px}.combo-indicators{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}.indicator-tag{background:#f0f0f0;border-radius:6px;color:#666;font-size:11px;font-weight:600;padding:4px 10px;text-transform:uppercase}.combo-stats{border-top:1px solid #f0f0f0;padding-top:12px}.stat-row{align-items:center;display:flex;font-size:13px;justify-content:space-between;margin:6px 0}.stat-row .stat-label{color:#666}.stat-row .stat-value{color:#333;font-weight:600}.stat-row .stat-value.buy{color:#26a69a}.stat-row .stat-value.sell{color:#ef5350}.all-combinations-table{margin-top:30px}.all-combinations-table h3{color:#333;font-size:18px;font-weight:600;margin:0 0 16px}.table-container{border-radius:8px;box-shadow:0 2px 8px #0000001a;overflow-x:auto}.all-combinations-table table{background:#fff;border-collapse:collapse;font-size:13px;width:100%}.all-combinations-table thead{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.all-combinations-table th{font-weight:600;padding:12px;text-align:left;white-space:nowrap}.all-combinations-table tbody tr{border-bottom:1px solid #f0f0f0;cursor:pointer;transition:background-color .2s ease}.all-combinations-table tbody tr:hover{background-color:#f9f9f9}.all-combinations-table tbody tr.selected{background-color:#667eea1a}.all-combinations-table td{padding:12px}.rank-cell{color:#667eea;font-weight:600}.combo-name-cell{color:#333;font-weight:500}.score-cell{color:#667eea;font-weight:600}.rating-badge{border-radius:6px;color:#fff;font-size:11px;font-weight:600;padding:4px 10px}.buy-cell{color:#26a69a;font-weight:600}.sell-cell{color:#ef5350;font-weight:600}.selected-combo-detail{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-top:30px;padding:24px}.selected-combo-detail h3{color:#333;font-size:18px;font-weight:600;margin:0 0 20px}.detail-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.detail-section h4{color:#667eea;font-size:16px;font-weight:600;margin:0 0 16px}.breakdown-item{border-bottom:1px solid #f0f0f0;display:flex;font-size:14px;justify-content:space-between;padding:10px 0}.breakdown-item:last-child{border-bottom:none}.breakdown-item span:first-child{color:#666}.breakdown-item span:last-child{color:#333;font-weight:600}.signal-bars{display:flex;flex-direction:column;gap:12px}.signal-bar{grid-gap:12px;align-items:center;display:grid;gap:12px;grid-template-columns:50px 1fr 60px}.bar-label{color:#666;font-size:13px;font-weight:600}.bar-track{background:#f0f0f0;border-radius:4px;height:8px;overflow:hidden}.bar-fill{border-radius:4px;height:100%;transition:width .3s ease}.buy-bar{background:linear-gradient(90deg,#26a69a,#20c997)}.sell-bar{background:linear-gradient(90deg,#ef5350,#f44336)}.hold-bar{background:linear-gradient(90deg,#999,#777)}.bar-value{color:#333;font-size:13px;font-weight:600;text-align:right}.empty-state{padding:80px 20px}.empty-state h3{color:#333;font-size:20px;font-weight:600;margin:20px 0 10px}.empty-state p{color:#666;font-size:14px;margin:6px 0}.empty-hint{color:#999;font-size:13px;margin-top:12px}.dark .combinations-header{border-bottom-color:#2b2b43}.dark .combo-header h4,.dark .header-content h2,.dark .stat-value{color:#d1d4dc}.dark .combination-card,.dark .selected-combo-detail,.dark .stat-card{background:#1a1d29}.dark .combination-card{border-color:#2b2b43}.dark .all-combinations-table table{background:#1a1d29}.dark .all-combinations-table tbody tr{border-bottom-color:#2b2b43}@media (max-width:768px){.combinations-header{align-items:flex-start;flex-direction:column;gap:16px}.run-analysis-btn{justify-content:center;width:100%}.combinations-grid,.detail-grid,.summary-stats{grid-template-columns:1fr}}.indicator-help-compact{background:var(--info-light);border-left:3px solid var(--info-color);border-radius:.375rem;color:var(--info-color);font-size:.875rem;margin-bottom:.75rem;padding:.75rem}.indicator-help-full{background:var(--card-bg);border:1px solid var(--border-color);border-radius:.5rem;margin-bottom:1.5rem;padding:1.5rem}.indicator-help-full h4{color:var(--text-primary);font-size:1.25rem;font-weight:700;margin:0 0 .75rem}.help-description{color:var(--text-secondary);font-size:.938rem;line-height:1.6;margin:0 0 1rem}.help-section{margin:1.25rem 0}.help-section h5{color:var(--text-primary);font-size:1rem;font-weight:600;margin:0 0 .5rem}.help-section ul{list-style-type:disc;margin:0;padding-left:1.5rem}.help-section li{color:var(--text-tertiary);font-size:.875rem;line-height:1.5;margin-bottom:.5rem}.help-parameters{grid-gap:.75rem;display:grid;gap:.75rem;margin:0}.help-parameters dt{color:var(--text-primary);font-size:.875rem;font-weight:600;margin-bottom:.25rem}.help-parameters dd{color:var(--text-tertiary);font-size:.875rem;line-height:1.5;margin:0 0 .5rem 1rem}.help-best-for{background:var(--gradient-primary);border-radius:.5rem;color:var(--text-inverse);font-size:.938rem;line-height:1.6;margin-top:1.25rem;padding:1rem}.help-best-for strong{display:block;font-size:1rem;margin-bottom:.25rem}.combination-help{background:var(--warning-light);border:1px solid var(--warning-color);border-radius:.5rem;margin:.75rem 0;padding:1rem}.combination-help h5{color:var(--warning-color);font-size:1rem;font-weight:700;margin:0 0 .5rem}.combination-help .help-description{color:var(--warning-color);font-size:.875rem;margin-bottom:.75rem}.help-strategy,.help-strength{background:var(--text-inverse-alpha-05);border-radius:.25rem;color:var(--warning-color);font-size:.875rem;line-height:1.5;margin:.5rem 0;padding:.5rem}.help-strategy strong,.help-strength strong{color:var(--warning-color);display:inline-block;margin-right:.5rem}.indicator-tooltip{align-items:center;cursor:help;display:inline-flex;position:relative}.indicator-tooltip-icon{color:var(--text-tertiary);height:16px;margin-left:.5rem;transition:color .2s;width:16px}.indicator-tooltip:hover .indicator-tooltip-icon{color:var(--primary-color)}.indicator-tooltip-content{background:var(--card-bg);border:1px solid var(--border-color);border-radius:.5rem;box-shadow:0 10px 25px var(--card-shadow-md);left:0;margin-top:.5rem;opacity:0;padding:1rem;position:absolute;top:100%;transition:opacity .2s,visibility .2s;visibility:hidden;width:320px;z-index:1000}.indicator-tooltip:hover .indicator-tooltip-content{opacity:1;visibility:visible}.indicator-tooltip-content:before{border:6px solid #0000;border-bottom:6px solid var(--card-bg);bottom:100%;content:"";left:1rem;position:absolute}.help-popover{background:var(--card-bg);border-radius:.75rem;box-shadow:0 25px 50px var(--card-shadow-lg);left:50%;max-height:80vh;max-width:600px;overflow-y:auto;padding:2rem;position:fixed;top:50%;transform:translate(-50%,-50%);width:90%;z-index:10000}.help-popover-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:var(--overlay-dark);bottom:0;left:0;position:fixed;right:0;top:0;z-index:9999}.help-popover-close{align-items:center;background:#0000;border:none;border-radius:.25rem;color:var(--text-tertiary);cursor:pointer;display:flex;font-size:1.5rem;height:32px;justify-content:center;position:absolute;right:1rem;top:1rem;transition:all .2s;width:32px}.help-popover-close:hover{background:var(--bg-tertiary);color:var(--text-primary)}.sidebar-help-icon{align-items:center;color:var(--text-tertiary);cursor:help;display:inline-flex;height:18px;justify-content:center;margin-left:.5rem;transition:color .2s;width:18px}.sidebar-help-icon:hover{color:var(--primary-color)}.parameter-help{background:var(--bg-secondary);border-left:3px solid var(--primary-color);border-radius:.25rem;color:var(--text-tertiary);font-size:.813rem;line-height:1.5;margin-top:.5rem;padding:.75rem}@media (max-width:768px){.indicator-tooltip-content{width:280px}.help-popover{padding:1.5rem;width:95%}.indicator-help-full{padding:1rem}}.configuration-manager{margin-bottom:1.5rem}.config-actions{display:flex;flex-wrap:wrap;gap:.75rem}.config-btn{align-items:center;background:var(--card-bg);border:1px solid var(--border-color);border-radius:.375rem;color:var(--text-primary);cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;padding:.625rem 1rem;position:relative;transition:all .2s}.config-btn:hover:not(:disabled){background:var(--bg-secondary);border-color:var(--primary-color);color:var(--primary-color)}.config-btn:disabled{cursor:not-allowed;opacity:.5}.config-btn.save-btn:hover:not(:disabled){background:var(--success-light);border-color:var(--success-color);color:var(--success-color)}.config-btn.load-btn:hover:not(:disabled){background:var(--info-light);border-color:var(--info-color);color:var(--info-color)}.config-btn.import-btn:hover{background:var(--warning-light);border-color:var(--warning-color);color:var(--warning-color)}.config-btn .badge{background:var(--primary-color);border-radius:9999px;color:var(--text-inverse);font-size:.75rem;font-weight:700;margin-left:.25rem;padding:.125rem .375rem}.modal-overlay{z-index:9998}.modal-dialog{background:var(--card-bg);border-radius:.75rem;box-shadow:0 25px 50px var(--card-shadow-lg);display:flex;flex-direction:column;left:50%;max-height:80vh;max-width:500px;overflow:hidden;position:fixed;top:50%;transform:translate(-50%,-50%);width:90%;z-index:9999}.modal-dialog.load-dialog{max-width:700px}.modal-header{background:var(--bg-secondary);padding:1.5rem}.modal-header h3{align-items:center;display:flex;gap:.5rem}.close-btn{color:var(--text-tertiary);padding:.25rem;transition:color .2s}.close-btn:hover{color:var(--text-primary)}.modal-footer{background:var(--bg-secondary)}.form-group input[type=text],.form-group textarea{border:1px solid var(--border-color);border-radius:.375rem;color:var(--text-primary);font-size:.875rem;padding:.625rem;transition:border-color .2s;width:100%}.form-group input[type=text]:focus,.form-group textarea:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px var(--primary-color-alpha-01);outline:none}.form-group textarea{font-family:inherit}.config-summary{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:.375rem;margin-top:1rem;padding:1rem}.config-summary h4{color:var(--text-primary);font-size:.875rem;font-weight:600;margin:0 0 .5rem}.config-summary ul{list-style-type:disc;margin:0;padding-left:1.25rem}.config-summary li{color:var(--text-tertiary);font-size:.813rem;margin-bottom:.25rem}.btn{border-radius:.375rem;font-weight:600;gap:.5rem;padding:.625rem 1.25rem}.btn-primary{background:#667eea}.btn-primary:hover{box-shadow:0 4px 6px var(--primary-shadow-md);transform:translateY(-1px)}.btn-secondary{background:var(--bg-tertiary)}.btn-secondary:hover{background:var(--border-color-dark)}.no-configs{align-items:center;color:var(--text-tertiary);display:flex;flex-direction:column;justify-content:center;padding:3rem 2rem;text-align:center}.no-configs p{font-size:.938rem;margin:.75rem 0 0}.configs-list{display:flex;flex-direction:column;gap:.75rem}.config-item{border:2px solid var(--border-color);border-radius:.5rem;cursor:pointer;padding:1rem;transition:all .2s}.config-item:hover{background:var(--bg-secondary);border-color:var(--primary-color)}.config-item.selected{background:var(--info-light);border-color:var(--primary-color)}.config-item-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:.5rem}.config-item-header h4{color:var(--text-primary);font-size:1rem;font-weight:600;margin:0}.config-item-actions{display:flex;gap:.25rem}.icon-btn{align-items:center;background:#0000;border:1px solid #0000;border-radius:.25rem;color:var(--text-tertiary);display:flex;padding:.375rem}.icon-btn:hover{background:var(--card-bg);border-color:var(--border-color);color:var(--text-primary)}.icon-btn.danger:hover{background:var(--error-light);border-color:var(--error-color);color:var(--error-color)}.config-description{color:var(--text-tertiary);font-size:.813rem;line-height:1.5;margin:0 0 .5rem}.config-meta{align-items:center;color:var(--text-tertiary);display:flex;font-size:.75rem;gap:.5rem}.config-meta span:nth-child(2){color:#d1d5db}@media (max-width:768px){.modal-dialog{max-height:90vh;width:95%}.modal-body,.modal-header{padding:1rem}.modal-footer{flex-wrap:wrap;padding:.75rem 1rem}.btn{flex:1 1;min-width:120px}.config-actions{width:100%}.config-btn{flex:1 1;justify-content:center}}.technical-sidebar{background:#fff;border-right:1px solid #e5e7eb;display:flex;flex-direction:column;flex-shrink:0;height:100%;min-width:70px;overflow:hidden;position:relative;transition:width .3s cubic-bezier(.4,0,.2,1);width:280px}.technical-sidebar.resizing{transition:none;-webkit-user-select:none;user-select:none}.technical-sidebar.collapsed{width:70px!important}.technical-sidebar.collapsed .sidebar-footer,.technical-sidebar.collapsed .technical-sidebar-content{opacity:0;overflow:hidden;pointer-events:none}.technical-sidebar.collapsed .sidebar-header h2{display:none}.technical-sidebar.collapsed .sidebar-header{justify-content:center;padding:1rem}.technical-sidebar-content{flex:1 1;min-height:0;overflow-x:hidden;overflow-y:auto;scroll-behavior:smooth;transition:opacity .3s ease}.technical-sidebar-content::-webkit-scrollbar{width:8px}.technical-sidebar-content::-webkit-scrollbar-track{background:#f1f5f9;border-radius:4px}.technical-sidebar-content::-webkit-scrollbar-thumb{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:4px;-webkit-transition:background .3s;transition:background .3s}.technical-sidebar-content::-webkit-scrollbar-thumb:hover{background:linear-gradient(135deg,#5568d3,#6b3fa2)}.sidebar-resize-handle{align-items:center;background:#0000;cursor:col-resize;display:flex;height:100%;justify-content:center;position:absolute;right:0;top:0;transition:background .2s;width:4px;z-index:20}.sidebar-resize-handle:hover{background:#667eea1a}.sidebar-resize-handle:hover .resize-handle-line{background:#667eea}.resize-handle-line{background:#e5e7eb;border-radius:2px;height:40px;transition:background .2s;width:2px}.technical-sidebar.resizing .sidebar-resize-handle{background:#667eea33}.technical-sidebar.resizing .resize-handle-line{background:#667eea;width:3px}.sidebar-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-bottom:2px solid #667eea;color:#fff;display:flex;flex-shrink:0;gap:.75rem;justify-content:space-between;min-height:60px;padding:1.5rem;position:-webkit-sticky;position:sticky;top:0;z-index:10}.sidebar-header-icon-only{width:100%}.sidebar-header-icon-only,.sidebar-toggle-btn{align-items:center;display:flex;justify-content:center}.sidebar-toggle-btn{background:#fff3;border:none;border-radius:50%;color:#fff;cursor:pointer;flex-shrink:0;height:32px;transition:all .3s ease;width:32px}.sidebar-toggle-btn:hover{background:#ffffff4d;transform:scale(1.1)}.sidebar-header h2{font-size:1.25rem;font-weight:600;margin:0}.sidebar-section{border-bottom:1px solid #e5e7eb}.section-header{background:#f9fafb;transition:background .2s}.section-header:hover{background:#f3f4f6}.section-header h3{align-items:center;color:#374151;display:flex;font-size:.95rem;gap:.5rem}.section-content{background:#fff;padding:1rem 1.25rem}.stock-select{background:#fff;border:1px solid #d1d5db;border-radius:.375rem;cursor:pointer;font-size:.875rem;padding:.625rem;transition:border-color .2s;width:100%}.stock-select:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.date-input-group{margin-bottom:.75rem}.date-input-group:last-child{margin-bottom:0}.date-input-group label{color:#6b7280;display:block;font-size:.8rem;font-weight:500;margin-bottom:.375rem}.date-input-group input[type=date]{border:1px solid #d1d5db;border-radius:.375rem;font-size:.875rem;padding:.5rem;transition:border-color .2s;width:100%}.date-input-group input[type=date]:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.indicators-section .section-content{max-height:none;padding:0}.indicators-scrollable{max-height:calc(100vh - 600px);min-height:300px;overflow-x:hidden;overflow-y:auto;padding:.5rem;scroll-behavior:smooth}.indicators-scrollable::-webkit-scrollbar{width:8px}.indicators-scrollable::-webkit-scrollbar-track{background:#f3f4f6;border-radius:4px;margin:4px 0}.indicators-scrollable::-webkit-scrollbar-thumb{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:4px;-webkit-transition:background .3s;transition:background .3s}.indicators-scrollable::-webkit-scrollbar-thumb:hover{background:linear-gradient(135deg,#5568d3,#6b3fa2)}.indicator-category{animation:fadeInUp .3s ease-out;margin-bottom:1.5rem}@keyframes fadeInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.category-header{align-items:flex-start;background:linear-gradient(135deg,#f9fafb,#fff);border-left:3px solid #667eea;border-radius:.5rem;gap:.75rem;margin-bottom:.75rem;padding:.75rem;transition:all .3s ease}.category-header:hover{background:linear-gradient(135deg,#f0f9ff,#fff);border-left-color:#764ba2;box-shadow:0 2px 8px #667eea1a;transform:translateX(2px)}.category-emoji{animation:pulse 2s ease-in-out infinite;flex-shrink:0;font-size:1.5rem}.category-info{flex:1 1}.category-name{color:#1f2937;font-size:.95rem;font-weight:700;letter-spacing:-.02em;margin:0 0 .25rem}.category-description{color:#6b7280;font-size:.75rem;line-height:1.4;margin:0}.category-indicators{padding-left:.5rem}.indicator-item{background:#fafafa;border:2px solid #e5e7eb;border-radius:.5rem;cursor:pointer;margin-bottom:.75rem;overflow:visible;padding:.75rem;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1)}.indicator-item:before{background:linear-gradient(90deg,#0000,#667eea1a);content:"";height:100%;left:0;pointer-events:none;position:absolute;top:0;transition:width .4s ease;width:0;z-index:0}.indicator-item:hover{background:#fff;border-color:#667eea;box-shadow:0 4px 12px #667eea26;transform:translateX(4px)}.indicator-item:hover:before{width:100%}.indicator-item.selected{background:linear-gradient(135deg,#667eea0d,#764ba20d);border-color:#667eea;box-shadow:0 2px 8px #667eea1f}.indicator-item.selected:after{align-items:center;animation:checkmarkPop .3s ease-out;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;color:#fff;content:"✓";display:flex;font-size:.75rem;font-weight:700;height:24px;justify-content:center;pointer-events:none;position:absolute;right:.5rem;top:.5rem;width:24px;z-index:1}@keyframes checkmarkPop{0%{transform:scale(0)}50%{transform:scale(1.2)}to{transform:scale(1)}}.indicator-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.375rem}.indicator-actions{gap:.5rem}.indicator-actions,.indicator-checkbox{align-items:center;display:flex;position:relative;z-index:2}.indicator-checkbox{cursor:pointer;flex:1 1}.indicator-checkbox input[type=checkbox]{cursor:pointer;height:1rem;margin-right:.5rem;pointer-events:auto;position:relative;width:1rem;z-index:3}.indicator-name{align-items:center;color:#1f2937;display:flex;font-size:.9rem;font-weight:500;gap:.375rem}.indicator-description{color:#6b7280;font-size:.75rem;margin-left:1.5rem;margin-top:.25rem}.help-btn{align-items:center;background:#f59e0b;border:none;border-radius:.25rem;color:#fff;cursor:pointer;display:flex;padding:.375rem;transition:all .2s}.help-btn:hover{background:#d97706;transform:scale(1.05)}.settings-btn{align-items:center;background:#667eea;border:none;border-radius:.25rem;color:#fff;cursor:pointer;display:flex;padding:.375rem;transition:background .2s}.settings-btn:hover{background:#5568d3}.parameter-section{background:#fff;border:1px solid #e5e7eb;border-radius:.375rem;margin-top:.75rem;padding:.75rem}.template-buttons{margin-bottom:.75rem}.template-buttons label{color:#6b7280;display:block;font-size:.75rem;font-weight:500;margin-bottom:.375rem}.template-grid{grid-gap:.375rem;display:grid;gap:.375rem;grid-template-columns:repeat(3,1fr)}.template-btn{background:#f3f4f6;border:1px solid #d1d5db;border-radius:.25rem;cursor:pointer;font-size:.75rem;padding:.375rem .5rem;text-align:center;transition:all .2s}.template-btn:hover{background:#667eea;border-color:#667eea;color:#fff}.parameter-inputs{gap:.5rem}.param-input,.parameter-inputs{display:flex;flex-direction:column}.param-input{gap:.25rem}.param-input.full-width{width:100%}.param-input label{color:#4b5563;font-size:.75rem;font-weight:500}.param-input input{border:1px solid #d1d5db;border-radius:.25rem;font-size:.8rem;padding:.375rem .5rem;transition:border-color .2s}.param-input input:focus{border-color:#667eea;box-shadow:0 0 0 2px #667eea1a;outline:none}.param-info{background:#f0f9ff;border:1px solid #bfdbfe;border-radius:.375rem;color:#1e40af;font-size:.8rem;line-height:1.5;padding:.75rem}.indicator-info{align-items:flex-start;background:#fef3c7;border:1px solid #fbbf24;border-radius:.375rem;color:#92400e;display:flex;font-size:.75rem;gap:.5rem;margin-top:1rem;padding:.75rem}.sidebar-footer{background:#f9fafb;border-top:2px solid #e5e7eb;bottom:0;flex-shrink:0;margin-top:auto;padding:1.25rem;position:-webkit-sticky;position:sticky;transition:opacity .3s ease;z-index:5}.analyze-btn{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:.5rem;box-shadow:0 4px 6px #667eea4d;color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:.5rem;justify-content:center;padding:.875rem;transition:all .3s;width:100%}.analyze-btn:hover:not(:disabled){box-shadow:0 6px 12px #667eea66;transform:translateY(-2px)}.analyze-btn:disabled{cursor:not-allowed;opacity:.5;transform:none}.analyze-btn .spin{animation:spin 1s linear infinite}.selected-count{color:#6b7280;font-size:.8rem;font-weight:500;margin-top:.75rem;text-align:center}.presets-section .section-header{cursor:default}.presets-section .section-header h3{align-items:center;display:flex;gap:.5rem}.preset-description{color:#6b7280;font-size:.875rem;line-height:1.6;margin:0 0 1rem}.preset-buttons{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}.preset-btn{align-items:center;background:#fff;border:2px solid #e5e7eb;border-radius:.625rem;cursor:pointer;display:flex;gap:1rem;padding:1rem;text-align:left;transition:all .2s}.preset-btn:hover{border-color:#667eea;box-shadow:0 4px 12px #667eea26;transform:translateY(-2px)}.preset-btn:active{transform:translateY(0)}.preset-conservative{background:linear-gradient(135deg,#d1fae5,#fff);border-color:#10b981}.preset-conservative:hover{border-color:#059669;box-shadow:0 4px 12px #10b98126}.preset-standard{background:linear-gradient(135deg,#e0e7ff,#fff);border-color:#667eea}.preset-standard:hover{border-color:#5568d3;box-shadow:0 4px 12px #667eea40}.preset-aggressive{background:linear-gradient(135deg,#fef3c7,#fff);border-color:#f59e0b}.preset-aggressive:hover{border-color:#d97706;box-shadow:0 4px 12px #f59e0b26}.preset-icon{flex-shrink:0;font-size:2rem}.preset-content{display:flex;flex:1 1;flex-direction:column;gap:.25rem}.preset-name{color:#1f2937;font-size:1rem;font-weight:700}.preset-hint{color:#6b7280;font-size:.8rem;line-height:1.4}.preset-info{align-items:center;background:linear-gradient(135deg,#e0e7ff,#f9fafb);border-radius:.5rem;color:#667eea;display:flex;font-size:.8rem;gap:.5rem;padding:.75rem}.technical-sidebar::-webkit-scrollbar{width:8px}.technical-sidebar::-webkit-scrollbar-track{background:#f1f5f9;border-radius:4px}.technical-sidebar::-webkit-scrollbar-thumb{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:4px;-webkit-transition:background .3s;transition:background .3s}.technical-sidebar::-webkit-scrollbar-thumb:hover{background:linear-gradient(135deg,#5568d3,#6b3fa2)}.combined-indicators-section{background:linear-gradient(135deg,#f0f9ff,#fff);border-top:2px solid #667eea}.combined-description{color:#6b7280;font-size:.875rem;line-height:1.5;margin-bottom:1rem}.voting-options{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}.voting-option{align-items:flex-start;background:#fff;border:2px solid #e5e7eb;border-radius:8px;cursor:pointer;display:flex;gap:.75rem;padding:1rem;transition:all .3s ease}.voting-option:hover{border-color:#667eea;box-shadow:0 2px 8px #667eea1a}.voting-option.active{background:#667eea0d;border-color:#667eea;box-shadow:0 2px 8px #667eea26}.voting-option input[type=radio]{accent-color:#667eea;cursor:pointer;margin-top:.25rem}.voting-option-content{flex:1 1}.voting-option-title{color:#1f2937;font-size:.9rem;font-weight:600;margin-bottom:.25rem}.voting-option-desc{color:#6b7280;font-size:.8rem;line-height:1.4}.selected-indicators-list{background:#fff;border:1px solid #e5e7eb;border-radius:8px;margin:1rem 0;padding:1rem}.selected-indicators-list h4{color:#374151;font-size:.9rem;font-weight:600;margin-bottom:.75rem}.indicators-badges{display:flex;flex-wrap:wrap;gap:.5rem}.indicator-badge{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:inline-flex;font-weight:500;padding:.375rem .75rem}.combined-info,.indicator-badge{border-radius:6px;font-size:.8rem}.combined-info{align-items:flex-start;background:#667eea0d;color:#667eea;display:flex;gap:.5rem;line-height:1.4;margin-top:.75rem;padding:.75rem}.combined-info svg{flex-shrink:0;margin-top:.125rem}@media (max-width:768px){.sidebar-header{padding:1rem}.sidebar-header h2{font-size:1.1rem}.section-content{padding:.75rem 1rem}.template-grid{grid-template-columns:1fr}.voting-options{gap:.5rem}.voting-option{padding:.75rem}}.candlestick-chart-container{background:#fff;border:1px solid #e5e7eb;border-radius:.75rem;margin-bottom:2rem;padding:1.5rem}.chart-controls{border-bottom:2px solid #f3f4f6;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem}.control-group{gap:.75rem}.control-btn,.control-group{align-items:center;display:flex}.control-btn{background:#fff;border:1px solid #d1d5db;border-radius:.375rem;color:#4b5563;cursor:pointer;font-size:.875rem;font-weight:500;gap:.5rem;padding:.5rem 1rem;transition:all .2s}.control-btn:hover{background:#f9fafb;border-color:#667eea;color:#667eea}.control-btn.active{background:#667eea;border-color:#667eea;color:#fff}.filter-group{align-items:center;display:flex;gap:.5rem}.filter-label{color:#4b5563;font-size:.875rem;font-weight:600;margin-right:.5rem}.filter-btn{align-items:center;background:#fff;border:1px solid #d1d5db;border-radius:.375rem;color:#4b5563;cursor:pointer;display:flex;font-size:.8rem;font-weight:500;gap:.375rem;padding:.375rem .75rem;transition:all .2s}.filter-btn:hover{background:#f9fafb;border-color:#9ca3af}.filter-btn.active{border-width:2px;font-weight:600}.filter-btn.bullish{border-color:#d1fae5;color:#10b981}.filter-btn.bullish.active{background:#d1fae5;border-color:#10b981;color:#065f46}.filter-btn.bearish{border-color:#fee2e2;color:#ef4444}.filter-btn.bearish.active{background:#fee2e2;border-color:#ef4444;color:#991b1b}.filter-btn.neutral{border-color:#f3f4f6;color:#6b7280}.filter-btn.neutral.active{background:#f3f4f6;border-color:#6b7280;color:#374151}.chart-wrapper{margin:1.5rem 0;min-height:500px}.candlestick-tooltip{background:#fff;border:2px solid #667eea;border-radius:.5rem;box-shadow:0 10px 25px #00000026;min-width:250px;padding:1rem}.tooltip-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;margin-bottom:.75rem;padding-bottom:.75rem}.tooltip-date{color:#1f2937;font-size:.95rem}.tooltip-trend{align-items:center;border-radius:.25rem;display:flex;font-size:.8rem;font-weight:600;gap:.25rem;padding:.25rem .5rem}.tooltip-trend.bullish{background:#d1fae5;color:#065f46}.tooltip-trend.bearish{background:#fee2e2;color:#991b1b}.tooltip-prices{margin-bottom:.75rem}.price-row{display:flex;font-size:.875rem;justify-content:space-between;padding:.375rem 0}.price-row span{color:#6b7280}.price-row strong{color:#1f2937;font-weight:600}.tooltip-patterns{border-top:1px solid #e5e7eb;padding-top:.75rem}.patterns-header{color:#667eea;font-size:.8rem;font-weight:700;letter-spacing:.5px;margin-bottom:.5rem;text-transform:uppercase}.pattern-tag-tooltip{align-items:center;color:#4b5563;display:flex;font-size:.8rem;gap:.5rem;padding:.375rem 0}.pattern-indicator{border-radius:50%;flex-shrink:0;height:8px;width:8px}.pattern-indicator.bullish{background:#10b981}.pattern-indicator.bearish{background:#ef4444}.pattern-indicator.neutral{background:#6b7280}.pattern-counts{display:flex;font-size:.75rem;font-weight:600;gap:1rem;margin-top:.5rem}.bullish-label{color:#10b981}.bearish-label{color:#ef4444}.neutral-label{color:#6b7280}.chart-summary{background:linear-gradient(135deg,#f9fafb,#f3f4f6);border:1px solid #e5e7eb;border-radius:.5rem;display:flex;flex-wrap:wrap;gap:1.5rem;padding:1rem}.summary-item{background:#fff;border:1px solid #e5e7eb;border-radius:.375rem;padding:.5rem 1rem}.summary-item.bullish{border-color:#d1fae5;color:#10b981}.summary-item.bearish{border-color:#fee2e2;color:#ef4444}.summary-item.neutral{border-color:#f3f4f6;color:#6b7280}.summary-item.confidence,.summary-item.signal{border-color:#667eea;border-width:2px}.summary-label{color:#6b7280;font-size:.875rem;font-weight:500}.summary-value{color:#1f2937;font-size:1rem}.candlestick-empty{align-items:center;color:#9ca3af;display:flex;flex-direction:column;gap:1rem;justify-content:center;padding:4rem 2rem}.candlestick-empty p{color:#6b7280;font-size:1rem}@media (max-width:1024px){.chart-controls{align-items:flex-start;flex-direction:column}.filter-group{flex-wrap:wrap}.chart-summary{gap:1rem}.summary-item{flex-basis:calc(50% - 0.5rem);flex-grow:1;flex-shrink:1;min-width:150px}}@media (max-width:768px){.candlestick-chart-container{padding:1rem}.chart-controls{gap:.75rem}.control-btn,.filter-btn{font-size:.75rem;padding:.375rem .625rem}.chart-wrapper{min-height:350px}.candlestick-tooltip{min-width:200px;padding:.75rem}.tooltip-date{font-size:.85rem}.price-row{font-size:.8rem}.chart-summary{gap:.75rem}.summary-item{flex:1 1 100%;padding:.375rem .75rem}.summary-label,.summary-value{font-size:.8rem}}.pattern-info-panel{background:var(--card-bg);border:1px solid var(--border-color);border-radius:.75rem;margin-bottom:2rem;padding:2rem}.info-overview{background:linear-gradient(135deg,var(--primary-color-alpha-015) 0,var(--primary-color-alpha-015) 100%);border:2px solid var(--primary-color);border-radius:.75rem;margin-bottom:2rem;padding:1.5rem}.overview-header{align-items:center;color:var(--primary-color);gap:.75rem;margin-bottom:1rem}.overview-header h3{font-size:1.5rem;font-weight:700;margin:0}.overview-text{color:var(--text-secondary);font-size:1rem;line-height:1.6;margin:0}.signal-explanation{margin-bottom:2rem}.signal-explanation h4{color:var(--text-primary);font-size:1.25rem;font-weight:700;margin:0 0 1rem}.signal-cards{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.signal-card{border:2px solid;border-radius:.5rem;display:flex;gap:1rem;padding:1.25rem;transition:all .2s}.signal-card:hover{box-shadow:0 4px 12px var(--card-shadow-md);transform:translateY(-2px)}.signal-card.buy{background:var(--success-light);border-color:var(--success-color);color:var(--success-color)}.signal-card.sell{background:var(--error-light);border-color:var(--error-color);color:var(--error-color)}.signal-card.hold{background:var(--bg-tertiary);border-color:var(--text-tertiary);color:var(--text-primary)}.signal-content h5{font-size:1rem;font-weight:700;margin:0 0 .5rem}.signal-content p{font-size:.875rem;line-height:1.5;margin:0}.pattern-search{margin-bottom:2rem}.search-input-wrapper{align-items:center;background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:.5rem;display:flex;gap:.75rem;padding:.75rem 1rem;transition:all .2s}.search-input-wrapper:focus-within{background:var(--card-bg);border-color:var(--primary-color);box-shadow:0 0 0 3px var(--primary-color-alpha-01)}.search-input-wrapper svg{color:var(--text-tertiary);flex-shrink:0}.search-input{background:#0000;border:none;color:var(--text-primary);flex:1 1;font-size:1rem;outline:none}.search-input::placeholder{color:var(--text-tertiary)}.pattern-categories{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:2rem}.pattern-category{border:1px solid var(--border-color);border-radius:.5rem;overflow:hidden}.category-header{align-items:center;cursor:pointer;display:flex;justify-content:space-between;padding:1rem 1.5rem;transition:all .2s;-webkit-user-select:none;user-select:none}.category-header:hover{background:var(--bg-secondary)}.category-header.bullish{background:linear-gradient(135deg,var(--success-light) 0,var(--success-light) 100%);color:var(--success-color)}.category-header.bearish{background:linear-gradient(135deg,var(--error-light) 0,var(--error-light) 100%);color:var(--error-color)}.category-header.neutral{background:linear-gradient(135deg,var(--bg-tertiary) 0,var(--border-color) 100%);color:var(--text-primary)}.category-title{align-items:center;display:flex;gap:.75rem}.category-title h4{font-size:1.1rem;font-weight:700;margin:0}.pattern-count{background:var(--card-bg);border-radius:999px;font-size:.875rem;font-weight:700;padding:.25rem .625rem}.category-content{background:var(--card-bg);display:flex;flex-direction:column;gap:1rem;padding:1rem}.pattern-card{border:2px solid;border-radius:.5rem;cursor:pointer;padding:1rem;transition:all .2s}.pattern-card:hover{box-shadow:0 4px 12px var(--card-shadow-md);transform:translateX(4px)}.pattern-card.selected{box-shadow:0 8px 20px var(--card-shadow-lg)}.pattern-card.bullish{background:linear-gradient(135deg,var(--success-light) 0,var(--card-bg) 100%);border-color:var(--success-light)}.pattern-card.bullish.selected{background:var(--success-light);border-color:var(--success-color)}.pattern-card.bearish{background:linear-gradient(135deg,var(--error-light) 0,var(--card-bg) 100%);border-color:var(--error-light)}.pattern-card.bearish.selected{background:var(--error-light);border-color:var(--error-color)}.pattern-card.neutral{background:linear-gradient(135deg,var(--bg-secondary) 0,var(--card-bg) 100%);border-color:var(--bg-tertiary)}.pattern-card.neutral.selected{background:var(--bg-tertiary);border-color:var(--text-tertiary)}.pattern-card-header{align-items:center;display:flex;gap:1rem}.pattern-icon{align-items:center;border-radius:.5rem;display:flex;flex-shrink:0;height:40px;justify-content:center;width:40px}.pattern-card.bullish .pattern-icon{background:var(--success-color);color:var(--text-inverse)}.pattern-card.bearish .pattern-icon{background:var(--error-color);color:var(--text-inverse)}.pattern-card.neutral .pattern-icon{background:var(--text-tertiary);color:var(--text-inverse)}.pattern-title{flex:1 1}.pattern-title h4{color:var(--text-primary);font-size:1rem;font-weight:700;margin:0}.pattern-code{color:var(--text-tertiary);font-family:monospace;font-size:.75rem}.strength-badge{border-radius:999px;font-size:.75rem;font-weight:600;letter-spacing:.5px;padding:.25rem .75rem;text-transform:uppercase}.strength-strong{background:var(--warning-light);color:var(--warning-color)}.strength-moderate{background:var(--info-light);color:var(--info-color)}.strength-weak{background:var(--bg-tertiary);color:var(--text-secondary)}.strength-context{background:var(--primary-light);color:var(--primary-hover)}.pattern-detail{border-top:2px solid var(--border-color);display:flex;flex-direction:column;gap:1rem;margin-top:1rem;padding-top:1rem}.detail-section h5{color:var(--primary-color);font-size:.875rem;font-weight:700;letter-spacing:.5px;margin:0 0 .5rem;text-transform:uppercase}.detail-section p{color:var(--text-secondary);font-size:.875rem;line-height:1.6;margin:0}.type-badge{align-items:center;border-radius:999px;display:inline-flex;font-size:.8rem;font-weight:700;gap:.5rem;padding:.375rem .75rem}.type-badge.bullish{background:var(--success-light);color:var(--success-color)}.type-badge.bearish{background:var(--error-light);color:var(--error-color)}.type-badge.neutral{background:var(--bg-tertiary);color:var(--text-secondary)}.usage-tips{background:linear-gradient(135deg,var(--warning-light) 0,var(--warning-light) 100%);border:2px solid var(--warning-color);border-radius:.75rem;margin-bottom:2rem;padding:1.5rem}.usage-tips h4{color:var(--warning-color);font-size:1.1rem;font-weight:700;margin:0 0 .75rem}.usage-tips p{color:var(--warning-color);font-size:.95rem;line-height:1.6;margin:0}.detected-summary{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:.75rem;padding:1.5rem}.detected-summary h4{color:var(--text-primary);font-size:1.1rem;font-weight:700;margin:0 0 1rem}.recent-patterns{display:flex;flex-direction:column;gap:.75rem}.recent-pattern-item{align-items:center;background:var(--card-bg);border:1px solid var(--border-color);border-radius:.5rem;display:flex;gap:1rem;justify-content:space-between;padding:.75rem 1rem}.pattern-date{color:var(--text-tertiary);font-size:.875rem;font-weight:600;white-space:nowrap}.pattern-badges{display:flex;flex-wrap:wrap;gap:.375rem}.pattern-mini-badge{border-radius:999px;font-size:.7rem;font-weight:600;padding:.25rem .5rem;white-space:nowrap}.pattern-mini-badge.bullish{background:var(--success-light);color:var(--success-color)}.pattern-mini-badge.bearish{background:var(--error-light);color:var(--error-color)}.pattern-mini-badge.neutral{background:var(--bg-tertiary);color:var(--text-secondary)}.pattern-info-empty,.pattern-info-loading{align-items:center;display:flex;flex-direction:column;gap:1rem;justify-content:center;padding:4rem 2rem}.pattern-info-loading .spinner{animation:spin 1s linear infinite;border:4px solid var(--bg-tertiary);border-radius:50%;border-top-color:var(--primary-color);height:48px;width:48px}.pattern-info-empty p,.pattern-info-loading p{color:var(--text-tertiary);font-size:1rem}.no-results,.pattern-info-empty svg{color:var(--text-tertiary)}.no-results{font-style:italic;padding:2rem}@media (max-width:1024px){.signal-cards{grid-template-columns:1fr}}@media (max-width:768px){.info-overview,.pattern-info-panel{padding:1rem}.overview-header h3{font-size:1.25rem}.signal-cards{gap:.75rem}.signal-card{padding:1rem}.category-header{padding:.75rem 1rem}.category-title h4{font-size:1rem}.pattern-card{padding:.75rem}.pattern-icon{height:32px;width:32px}.recent-pattern-item{align-items:flex-start;flex-direction:column}.pattern-badges{width:100%}}.indicator-view{margin-bottom:2rem}.candlestick-patterns-view{background:var(--bg-secondary);border-radius:.75rem;padding:1.5rem}.bullish-count{color:var(--success-color);font-weight:700}.bearish-count{color:var(--error-color);font-weight:700}.neutral-count{color:var(--text-tertiary);font-weight:700}.loading-state{align-items:center;display:flex;flex-direction:column;gap:1rem;justify-content:center;padding:4rem 2rem}.loading-state .spinner{animation:spin 1s linear infinite;border:4px solid var(--bg-tertiary);border-radius:50%;border-top-color:var(--primary-color);height:48px;width:48px}.loading-state p{color:var(--text-tertiary);font-size:1rem;margin:0}.error-state{align-items:center;background:var(--error-light);border:2px solid var(--error-color);border-radius:.75rem;display:flex;flex-direction:column;gap:1rem;justify-content:center;padding:4rem 2rem}.error-state p{color:var(--error-color);font-size:1rem;font-weight:600;margin:0}.retry-btn{background:var(--error-color);border-radius:.375rem;font-weight:600;padding:.5rem 1.5rem;transition:all .2s}.retry-btn:hover{background:var(--error-hover);transform:translateY(-1px)}.error-message{border-radius:.5rem;padding:2rem;text-align:center}.error-message p{color:var(--error-color);font-size:1rem;font-weight:600;margin:0}.no-data-state{align-items:center;color:var(--text-tertiary);display:flex;flex-direction:column;justify-content:center;padding:4rem 2rem}.no-data-state p{font-size:1rem;margin:0}.indicator-description{background:linear-gradient(135deg,var(--primary-color-alpha-015) 0,var(--primary-color-alpha-015) 100%);border:1px solid var(--primary-color);border-radius:.5rem;margin-bottom:1.5rem;padding:1rem 1.25rem}.indicator-description p{color:var(--text-primary);font-size:.95rem;line-height:1.6;margin:0}.indicator-description strong{color:var(--primary-color);font-weight:600}.chart-container{background:var(--card-bg);border:1px solid var(--border-color);border-radius:.5rem;margin-bottom:1.5rem;padding:1.5rem}.chart-container h4{border-bottom:2px solid var(--border-color);color:var(--text-primary);font-size:1rem;font-weight:600;margin:0 0 1.5rem;padding-bottom:.75rem}.recharts-cartesian-axis-tick-value{fill:var(--text-tertiary);font-size:.8rem}.recharts-legend-wrapper{padding-top:1rem}.recharts-legend-item-text{color:var(--text-secondary);font-size:.875rem}.recharts-tooltip-wrapper{outline:none}.recharts-default-tooltip{background:var(--card-bg)!important;border:1px solid var(--border-color)!important;border-radius:.375rem!important;box-shadow:0 4px 6px var(--card-shadow-sm)!important;padding:.75rem!important}.recharts-tooltip-label{color:var(--text-primary);font-weight:600;margin-bottom:.5rem}.recharts-tooltip-item{color:var(--text-secondary);font-size:.875rem}@media (max-width:768px){.indicator-description{padding:.875rem 1rem}.indicator-description p{font-size:.875rem}.chart-container{padding:1rem}.chart-container h4{font-size:.95rem;margin-bottom:1rem}.recharts-cartesian-axis-tick-value{font-size:.7rem}.recharts-legend-item-text{font-size:.8rem}}.voting-results-table{background:#fff;border:1px solid #e5e7eb;border-radius:.75rem;margin-bottom:2rem;overflow:hidden}.table-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;justify-content:space-between;padding:1.25rem 1.5rem}.table-header h3{font-size:1.25rem;font-weight:600;margin:0}.combination-count{display:inline-block;font-size:.875rem;font-weight:400;margin-left:.75rem;opacity:.9}.export-btn-small,.toggle-all-btn{align-items:center;background:#ffffff1a;border:1px solid #ffffff4d;border-radius:.375rem;color:#fff;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;padding:.5rem 1rem;transition:all .2s}.export-btn-small:hover,.toggle-all-btn:hover{background:#fff3;border-color:#ffffff80}.table-wrapper{max-height:700px;overflow-y:auto}.combinations-table{font-size:.875rem}.combinations-table thead{box-shadow:0 1px 3px #0000000d;position:-webkit-sticky;position:sticky;top:0;z-index:10}.combinations-table th{padding:1rem;-webkit-user-select:none;user-select:none}.combinations-table th.sortable{cursor:pointer;transition:background .2s}.combinations-table th.sortable:hover{background:#f3f4f6}.th-content{align-items:center;display:flex;gap:.375rem;justify-content:center}.text-center{text-align:center!important}.expand-column{text-align:center;width:50px}.expand-btn{align-items:center;background:#0000;border:1px solid #d1d5db;border-radius:.25rem;color:#6b7280;cursor:pointer;display:flex;justify-content:center;padding:.25rem;transition:all .2s}.expand-btn:hover{background:#f3f4f6;border-color:#667eea;color:#667eea}.combo-row{transition:all .2s}.combo-row:hover{background:#fafafa}.combo-row.expanded{background:#f9fafb;border-left:3px solid #667eea}.combinations-table td{padding:1rem}.combo-name{font-size:.95rem}.indicators-list{max-width:300px}.indicator-tags{display:flex;flex-wrap:wrap;gap:.375rem}.indicator-tag{background:#e0e7ff;border-radius:999px;color:#4f46e5;font-size:.75rem;font-weight:500;padding:.25rem .625rem}.count-cell{align-items:center;display:flex;flex-direction:column;gap:.25rem}.count-cell .count{font-size:1.1rem;font-weight:700}.count-cell .percentage{color:#6b7280;font-size:.75rem}.buy-count .count{color:#059669}.sell-count .count{color:#dc2626}.hold-count .count{color:#6b7280}.signal-badge{align-items:center;display:inline-flex;gap:.375rem;padding:.375rem .75rem}.signal-badge.small{font-size:.7rem;padding:.25rem .5rem}.confidence-cell{min-width:120px}.confidence-indicator{display:flex;flex-direction:column;gap:.375rem}.confidence-value{color:#667eea;font-size:1rem;font-weight:700}.confidence-bar{background:#e5e7eb;border-radius:999px;height:6px;overflow:hidden}.confidence-fill{background:linear-gradient(90deg,#667eea,#764ba2);height:100%;transition:width .3s ease}.expanded-row{background:#fafafa}.expanded-row td{border-bottom:2px solid #e5e7eb;padding:0!important}.expanded-content{background:#fff;border-left:3px solid #667eea;padding:1.5rem}.expanded-content h4{align-items:center;color:#374151;display:flex;font-size:1rem;font-weight:600;gap:.5rem;margin:0 0 1rem}.signals-timeline{background:#fafafa;border:1px solid #e5e7eb;border-radius:.5rem;overflow-x:auto;padding:1rem}.timeline-table{border-collapse:collapse;font-size:.8rem;width:100%}.timeline-table thead{background:#fff}.timeline-table th{border-bottom:2px solid #e5e7eb;color:#374151;font-weight:600;padding:.625rem .75rem;text-align:center;white-space:nowrap}.timeline-table td{border-bottom:1px solid #f3f4f6;padding:.625rem .75rem}.timeline-table tbody tr:hover{background:#fff}.timeline-date{color:#4b5563;font-weight:500;white-space:nowrap}.buy-vote{color:#059669;font-weight:600}.sell-vote{color:#dc2626;font-weight:600}.hold-vote{color:#6b7280;font-weight:600}.volume-filter{color:#6b7280;font-size:.75rem;font-style:italic}.no-combinations{align-items:center;color:#9ca3af;display:flex;flex-direction:column;gap:1rem;padding:4rem 2rem;text-align:center}.no-combinations p{color:#6b7280;font-size:1rem;margin:0}.signals-timeline::-webkit-scrollbar,.table-wrapper::-webkit-scrollbar{height:8px;width:8px}.signals-timeline::-webkit-scrollbar-track,.table-wrapper::-webkit-scrollbar-track{background:#f1f1f1}.signals-timeline::-webkit-scrollbar-thumb,.table-wrapper::-webkit-scrollbar-thumb{background:#667eea;border-radius:4px}.signals-timeline::-webkit-scrollbar-thumb:hover,.table-wrapper::-webkit-scrollbar-thumb:hover{background:#5568d3}@media (max-width:1024px){.table-header{align-items:flex-start;flex-direction:column;gap:1rem}.combinations-table td,.combinations-table th{font-size:.8rem;padding:.75rem .625rem}.indicator-tags{flex-direction:column}.expanded-content{padding:1rem}}@media (max-width:768px){.table-header h3{font-size:1.1rem}.combination-count{display:block;margin-left:0;margin-top:.25rem}.header-actions{justify-content:space-between;width:100%}.combinations-table{font-size:.75rem}.indicator-tag{font-size:.7rem;padding:.2rem .5rem}.count-cell .count{font-size:1rem}.signal-badge{font-size:.7rem;padding:.3rem .6rem}.timeline-table{font-size:.75rem}.timeline-table td,.timeline-table th{padding:.5rem}}.combination-signal-view{max-width:100%;width:100%}.consensus-banner{align-items:center;border:3px solid;border-radius:1rem;box-shadow:0 8px 24px var(--card-shadow-lg);display:flex;gap:2rem;margin-bottom:2rem;padding:2rem;transition:all .3s}.consensus-banner.buy{background:linear-gradient(135deg,var(--success-color-alpha-02) 0,var(--success-color-alpha-015) 100%);border-color:var(--success-color)}.consensus-banner.sell{background:linear-gradient(135deg,var(--error-color-alpha-02) 0,var(--error-color-alpha-015) 100%);border-color:var(--error-color)}.consensus-banner.hold{background:linear-gradient(135deg,var(--text-tertiary-alpha-02) 0,var(--text-tertiary-alpha-015) 100%);border-color:var(--text-tertiary)}.consensus-icon{align-items:center;border-radius:50%;box-shadow:0 4px 12px var(--card-shadow-lg);display:flex;flex-shrink:0;height:80px;justify-content:center;width:80px}.consensus-banner.buy .consensus-icon{background:linear-gradient(135deg,var(--success-color) 0,var(--success-hover) 100%);color:var(--text-inverse)}.consensus-banner.sell .consensus-icon{background:linear-gradient(135deg,var(--error-color) 0,var(--error-hover) 100%);color:var(--text-inverse)}.consensus-banner.hold .consensus-icon{background:linear-gradient(135deg,var(--text-tertiary) 0,var(--text-secondary) 100%);color:var(--text-inverse)}.consensus-icon svg{height:40px;width:40px}.consensus-content{flex:1 1}.consensus-content h3{color:var(--text-primary);font-size:1.75rem;font-weight:700;margin:0 0 .5rem}.consensus-content p{color:var(--text-secondary);font-size:1.1rem;margin:0 0 1rem}.consensus-strength{align-items:center;display:flex;gap:1rem}.strength-bar{background:var(--border-color-dark);border-radius:6px;flex:1 1;height:12px;overflow:hidden;position:relative}.strength-fill{background:var(--gradient-primary);border-radius:6px;height:100%;transition:width .5s ease}.consensus-banner.buy .strength-fill{background:linear-gradient(90deg,var(--success-color) 0,var(--success-hover) 100%)}.consensus-banner.sell .strength-fill{background:linear-gradient(90deg,var(--error-color) 0,var(--error-hover) 100%)}.consensus-banner.hold .strength-fill{background:linear-gradient(90deg,var(--text-tertiary) 0,var(--text-secondary) 100%)}.strength-label{color:var(--text-primary);font-size:.95rem;font-weight:600;white-space:nowrap}.voting-rules-panel{background:linear-gradient(135deg,var(--primary-color-alpha-015) 0,var(--secondary-color-alpha-015) 100%);border:2px solid var(--primary-color);border-radius:.75rem;margin-bottom:2rem;padding:1.5rem}.voting-rules-panel h3{color:var(--primary-color);font-size:1.25rem;font-weight:700;margin:0 0 1.25rem}.rules-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.rule-card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:.5rem;padding:1rem;transition:all .2s}.rule-card:hover{border-color:var(--primary-color);box-shadow:0 4px 12px var(--primary-shadow-md);transform:translateY(-2px)}.rule-header{color:var(--primary-color);font-size:.95rem;font-weight:700;margin-bottom:.5rem}.rule-content{color:var(--text-secondary);font-size:.875rem;line-height:1.5}.stat-card{border:1px solid var(--border-color);gap:1rem}.stat-card:hover{border-color:var(--primary-color);box-shadow:0 6px 20px var(--card-shadow-md)}.stat-icon{background:var(--gradient-primary);border-radius:.5rem;height:48px;width:48px}.stat-icon.consensus-icon{background:linear-gradient(135deg,var(--success-color) 0,var(--success-hover) 100%)}.stat-label{margin-bottom:.375rem}.stat-value{margin-bottom:.25rem}.stat-value.buy{color:var(--success-color)}.stat-value.sell{color:var(--error-color)}.stat-sublabel,.stat-value.hold{color:var(--text-tertiary)}.stat-sublabel{font-size:.75rem}.charts-section{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));margin-bottom:2rem}.chart-card{border-radius:.75rem;box-shadow:0 1px 3px var(--card-shadow)}.chart-card h4{border-bottom:2px solid var(--border-color);color:var(--text-primary);font-size:1rem;font-weight:600;margin:0 0 1.5rem;padding-bottom:.75rem}.top-combinations{background:var(--card-bg);border:1px solid var(--border-color);border-radius:.75rem;margin-bottom:2rem;padding:1.5rem}.top-combinations h3{color:var(--text-primary);font-size:1.25rem;font-weight:700;margin:0 0 1.5rem}.top-combinations-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.top-combo-card{background:linear-gradient(135deg,var(--bg-secondary) 0,var(--bg-tertiary) 100%);border:2px solid var(--border-color);border-radius:.5rem;display:flex;gap:1rem;overflow:hidden;padding:1.25rem;position:relative;transition:all .2s}.top-combo-card:before{background:var(--gradient-primary);content:"";height:100%;left:0;position:absolute;top:0;width:4px}.top-combo-card:hover{border-color:var(--primary-color);box-shadow:0 4px 12px var(--primary-shadow-md);transform:translateY(-2px)}.top-combo-rank{align-items:center;background:var(--gradient-primary);border-radius:50%;color:var(--text-inverse);display:flex;flex-shrink:0;font-size:1.1rem;font-weight:700;height:40px;justify-content:center;width:40px}.top-combo-content{flex:1 1}.top-combo-name{color:var(--text-primary);font-size:.95rem;font-weight:700;margin-bottom:.5rem}.top-combo-indicators{display:flex;flex-wrap:wrap;gap:.375rem;margin-bottom:.75rem}.indicator-tag-small{background:var(--primary-light);border-radius:999px;color:var(--primary-hover);font-size:.7rem;font-weight:500;padding:.2rem .5rem}.top-combo-stats{display:flex;font-size:.875rem;gap:1.5rem}.top-combo-confidence,.top-combo-signal{align-items:center;display:flex;gap:.5rem}.top-combo-stats .label{color:var(--text-tertiary);font-weight:500}.top-combo-stats .value{color:var(--primary-color);font-weight:700}.signal-badge-mini{border-radius:999px;font-size:.7rem;font-weight:600;padding:.25rem .5rem;text-transform:uppercase}.signal-badge-mini.buy{background:var(--success-light);color:var(--success-color)}.signal-badge-mini.sell{background:var(--error-light);color:var(--error-color)}.signal-badge-mini.hold{background:var(--bg-tertiary);color:var(--text-secondary)}.no-data-message{align-items:center;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:.75rem;color:var(--text-tertiary);display:flex;flex-direction:column;gap:1rem;padding:4rem 2rem;text-align:center}.no-data-message p{color:var(--text-tertiary);font-size:1rem;margin:0}@media (max-width:1024px){.rules-grid{grid-template-columns:repeat(2,1fr)}.charts-section{grid-template-columns:1fr}.stats-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.voting-rules-panel{padding:1rem}.voting-rules-panel h3{font-size:1.1rem}.rules-grid,.stats-grid{grid-template-columns:1fr}.stat-card{padding:1rem}.stat-icon{height:40px;width:40px}.stat-value{font-size:1.5rem}.charts-section{gap:1rem}.chart-card,.top-combinations{padding:1rem}.top-combinations-grid{grid-template-columns:1fr}.top-combo-card{padding:1rem}.top-combo-stats{flex-direction:column;gap:.5rem}}.combination-leaderboard{background:#fff;border-radius:.75rem;box-shadow:0 4px 6px #0000001a;margin-bottom:2rem;overflow:hidden}.leaderboard-header{align-items:center;background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;display:flex;gap:1rem;padding:1.5rem 2rem}.leaderboard-header h3{font-size:1.5rem;font-weight:700;margin:0}.leaderboard-subtitle{font-size:.875rem;margin:.5rem 0 0;opacity:.9}.no-data{padding:3rem 2rem}.podium{background:linear-gradient(180deg,#fef3c7,#fff);border-bottom:2px solid #fbbf24;padding:2rem}.podium-title{align-items:center;color:#92400e;font-size:1.125rem;font-weight:700;gap:.5rem;margin-bottom:1.5rem}.podium-places,.podium-title{display:flex;justify-content:center}.podium-places{align-items:flex-end;gap:1rem;margin:0 auto;max-width:900px}.podium-place{align-items:center;background:#fff;border-radius:.75rem;box-shadow:0 4px 6px #0000001a;display:flex;flex:1 1;flex-direction:column;padding:1.5rem 1rem;position:relative;transition:transform .3s,box-shadow .3s}.podium-place:hover{box-shadow:0 10px 20px #00000026;transform:translateY(-5px)}.podium-place.first{background:linear-gradient(180deg,#fffbeb,#fff);border:3px solid #fbbf24;order:2;padding:2rem 1rem}.podium-place.second{border:2px solid #d1d5db;order:1;padding:1.5rem 1rem}.podium-place.third{border:2px solid #cd7f32;order:3;padding:1.25rem 1rem}.podium-medal{align-items:center;display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.medal{filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.medal.gold{animation:shine 2s ease-in-out infinite;color:#fbbf24}.medal.silver{color:#9ca3af}.medal.bronze{color:#cd7f32}.medal.animated{animation:bounce 2s ease-in-out infinite,shine 2s ease-in-out infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes shine{0%,to{filter:drop-shadow(0 2px 4px rgba(251,191,36,.5))}50%{filter:drop-shadow(0 4px 8px rgba(251,191,36,.8))}}.place-number{color:#6b7280;font-size:.875rem;font-weight:700}.podium-info{text-align:center;width:100%}.combination-name{color:#374151;font-size:.875rem;font-weight:600;margin-bottom:.75rem;word-break:break-word}.combination-name.champion{color:#92400e;font-size:1rem;font-weight:700}.profit-display{display:flex;flex-direction:column;gap:.25rem;margin-bottom:.75rem}.profit-display.champion{margin-bottom:1rem}.profit-value{font-size:1.25rem;font-weight:700}.profit-display.champion .profit-value{font-size:1.5rem}.profit-value.positive{color:#10b981}.profit-value.negative{color:#ef4444}.podium-stats,.profit-amount{color:#6b7280;font-size:.75rem}.podium-stats{display:flex;flex-direction:column;gap:.25rem}.sort-controls{align-items:center;background:#f9fafb;border-bottom:1px solid #e5e7eb;display:flex;flex-wrap:wrap;gap:1rem;padding:1rem 2rem}.sort-label{color:#6b7280;font-size:.875rem;font-weight:600}.sort-buttons{display:flex;flex-wrap:wrap;gap:.5rem}.sort-btn{align-items:center;background:#fff;border:1px solid #d1d5db;border-radius:.375rem;color:#6b7280;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.375rem;padding:.5rem 1rem;transition:all .2s}.sort-btn:hover{background:#fffbeb;border-color:#f59e0b;color:#f59e0b}.sort-btn.active{background:#f59e0b;border-color:#f59e0b;color:#fff}.sort-order{color:#f59e0b;font-size:1.25rem;font-weight:700;margin-left:auto}.leaderboard-table{overflow-x:auto}.leaderboard-table table{border-collapse:collapse;width:100%}.leaderboard-table thead{background:#f9fafb;border-bottom:2px solid #e5e7eb}.leaderboard-table th{color:#374151;font-size:.813rem;font-weight:700;letter-spacing:.05em;padding:1rem;text-align:left;text-transform:uppercase}.leaderboard-table tbody tr{border-bottom:1px solid #f3f4f6;transition:background .2s}.leaderboard-table tbody tr:hover{background:#fafafa}.leaderboard-table tbody tr.top-three{background:#fffbeb}.leaderboard-table tbody tr.top-three:hover{background:#fef3c7}.leaderboard-table td{color:#4b5563;font-size:.875rem;padding:1rem}.rank-cell{color:#374151;font-weight:700}.rank-number{color:#9ca3af;display:inline-block;font-weight:600;text-align:center;width:32px}.combination-cell strong{color:#1f2937}.profit-cell{align-items:center;display:flex;font-weight:600;gap:.5rem}.profit-cell.positive{color:#10b981}.profit-cell.negative{color:#ef4444}.performance-badge{border-radius:9999px;display:inline-block;font-size:.75rem;font-weight:700;letter-spacing:.05em;padding:.375rem .75rem;text-transform:uppercase}.performance-badge.excellent{background:#d1fae5;color:#065f46}.performance-badge.good{background:#dbeafe;color:#1e40af}.performance-badge.neutral{background:#f3f4f6;color:#4b5563}.performance-badge.poor{background:#fed7aa;color:#92400e}.performance-badge.bad{background:#fee2e2;color:#991b1b}@media (max-width:1024px){.podium-places{align-items:center;flex-direction:column}.podium-place.first,.podium-place.second,.podium-place.third{max-width:400px;order:0;width:100%}.sort-controls{align-items:flex-start;flex-direction:column}.sort-order{margin-left:0;margin-top:.5rem}}@media (max-width:768px){.leaderboard-header{padding:1rem}.leaderboard-header h3{font-size:1.125rem}.podium,.sort-controls{padding:1rem}.leaderboard-table{font-size:.75rem}.leaderboard-table td,.leaderboard-table th{padding:.5rem}}.backtesting-view{margin:0 auto;max-width:1600px;padding:2rem}.backtest-header{margin-bottom:2rem}.backtest-header h2{color:var(--text-primary);font-size:2rem;font-weight:700;margin:0 0 .5rem}.header-subtitle{font-size:1rem;line-height:1.6}.backtest-config{grid-gap:2rem;background:var(--card-bg);border:2px solid var(--border-color);border-radius:.75rem;display:grid;gap:2rem;grid-template-columns:1fr 1fr 1fr;margin-bottom:2rem;padding:2rem}.config-section{display:flex;flex-direction:column;gap:.75rem}.config-section label{color:var(--text-primary);font-size:.95rem;font-weight:600}.capital-input-wrapper{align-items:center;background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:.5rem;display:flex;gap:.75rem;padding:.75rem 1rem;transition:all .2s}.capital-input-wrapper:focus-within{background:var(--card-bg);border-color:var(--primary-color);box-shadow:0 0 0 3px var(--primary-color-alpha-01)}.capital-input-wrapper svg{color:var(--primary-color);flex-shrink:0}.capital-input{background:#0000;border:none;color:var(--text-primary);flex:1 1;font-size:1.1rem;font-weight:600;outline:none}.input-hint{color:var(--text-tertiary);font-size:.875rem}.error-hint{color:var(--error-color);font-size:.875rem;font-weight:500}.strategy-buttons{display:flex;gap:.75rem}.strategy-btn{background:var(--card-bg);border:2px solid var(--border-color);border-radius:.5rem;color:var(--text-tertiary);cursor:pointer;flex:1 1;font-size:.95rem;font-weight:600;padding:.875rem 1.25rem;transition:all .2s}.strategy-btn:hover{background:var(--bg-secondary);border-color:var(--primary-color);color:var(--primary-color)}.strategy-btn.active{background:var(--gradient-primary);border-color:var(--primary-color);color:var(--text-inverse)}.run-backtest-btn{align-items:center;background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:.5rem;color:var(--text-inverse);cursor:pointer;display:flex;font-size:1.1rem;font-weight:700;gap:.75rem;justify-content:center;padding:1rem 2rem;transition:all .2s;width:100%}.run-backtest-btn:hover:not(:disabled){box-shadow:0 10px 25px var(--success-color-alpha-02);transform:translateY(-2px)}.run-backtest-btn:disabled{background:var(--text-tertiary);cursor:not-allowed}.performance-cards{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-bottom:2rem}.perf-card{align-items:flex-start;background:var(--card-bg);border:2px solid var(--border-color);border-radius:.75rem;display:flex;gap:1.25rem;padding:1.5rem;transition:all .2s}.perf-card:hover{box-shadow:0 10px 25px var(--card-shadow-md);transform:translateY(-3px)}.perf-card.profit-positive{background:linear-gradient(135deg,#d1fae5,#fff);border-color:#10b981}.perf-card.profit-negative{background:linear-gradient(135deg,var(--error-light) 0,var(--card-bg) 100%);border-color:var(--error-color)}.perf-icon{align-items:center;background:var(--gradient-primary);border-radius:.75rem;color:var(--text-inverse);display:flex;flex-shrink:0;height:56px;justify-content:center;width:56px}.profit-positive .perf-icon{background:linear-gradient(135deg,#10b981,#059669)}.profit-negative .perf-icon{background:linear-gradient(135deg,var(--error-color) 0,var(--error-hover) 100%)}.perf-content{display:flex;flex:1 1;flex-direction:column;gap:.25rem}.perf-label{color:var(--text-tertiary);font-size:.875rem;font-weight:500}.perf-value{color:var(--text-primary);font-size:1.75rem;font-weight:700}.perf-sublabel{color:var(--text-tertiary);font-size:.875rem}.chart-section{background:var(--card-bg);border:2px solid var(--border-color);padding:2rem}.chart-section h3{font-size:1.5rem;font-weight:700;margin:0 0 .5rem}.chart-subtitle{color:var(--text-tertiary);font-size:.95rem;margin:0 0 1.5rem}.trades-section{background:var(--card-bg);border:2px solid var(--border-color);border-radius:.75rem;margin-bottom:2rem;padding:2rem}.trades-section h3{color:var(--text-primary);font-size:1.5rem;font-weight:700;margin:0 0 .5rem}.section-subtitle{margin:0 0 1.5rem}.trade-badge{border-radius:999px;display:inline-block;font-size:.8rem;font-weight:700;padding:.375rem .875rem}.trade-badge.buy{background:var(--success-light);color:var(--success-hover)}.trade-badge.sell{background:var(--error-light);color:var(--error-hover)}.combination-results{margin-bottom:2rem}.combination-results h3{color:var(--text-primary);font-size:1.75rem;font-weight:700;margin:0 0 .5rem}.comparison-summary{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-bottom:2rem}.comparison-card{background:var(--card-bg);border:3px solid;border-radius:.75rem;padding:2rem;text-align:center}.comparison-card.best{background:linear-gradient(135deg,var(--warning-light) 0,var(--card-bg) 100%);border-color:var(--warning-color)}.comparison-card.best-winrate{background:linear-gradient(135deg,#d1fae5,#fff);border-color:#10b981}.comparison-card.average{background:linear-gradient(135deg,var(--primary-light) 0,var(--card-bg) 100%);border-color:var(--primary-color)}.comparison-card h4{color:var(--text-primary);font-size:1.1rem;font-weight:700;margin:0 0 1rem}.strategy-name{color:var(--text-tertiary);font-size:1rem;font-weight:600;margin:0 0 .75rem}.strategy-profit{color:var(--text-primary);font-size:1.5rem;font-weight:700;margin:0}.profit-pct{color:var(--success-color);display:block;font-size:1rem;margin-top:.25rem}.results-table{background:var(--card-bg);border:2px solid var(--border-color);border-radius:.75rem;overflow:hidden}.backtest-table{border-collapse:collapse;width:100%}.backtest-table thead{background:var(--gradient-primary);color:var(--text-inverse)}.backtest-table th{font-size:.875rem;font-weight:700;letter-spacing:.5px;padding:1rem;text-align:left;text-transform:uppercase}.backtest-table td{border-bottom:1px solid var(--border-color);font-size:.95rem;padding:1rem}.backtest-table tbody tr:hover{background:var(--bg-secondary)}.rank-cell{font-size:1.25rem;text-align:center;width:60px}.strategy-cell{color:var(--text-primary);font-weight:600}.indicators-cell{display:flex;flex-wrap:wrap;gap:.375rem}.indicator-mini-tag{background:var(--primary-light);border-radius:999px;color:var(--primary-hover);font-size:.75rem;font-weight:500;padding:.25rem .5rem}.number-cell{font-weight:500;text-align:right}.number-cell.positive{color:var(--success-color);font-weight:700}.number-cell.negative{color:var(--error-color);font-weight:700}.best-strategy-detail{background:linear-gradient(135deg,var(--warning-light) 0,var(--card-bg) 100%);border:3px solid #fbbf24;border-radius:.75rem;margin-top:3rem;padding:2rem}.best-strategy-detail h3{color:var(--warning-color);font-size:1.75rem;font-weight:700;margin:0 0 2rem}.error-message{border:2px solid var(--error-color);border-radius:.75rem;color:var(--error-hover);font-weight:600;gap:1rem;padding:1.25rem 1.5rem}.empty-state,.error-message{align-items:center;display:flex}.empty-state{color:var(--text-tertiary);flex-direction:column;justify-content:center;padding:6rem 2rem}.empty-state h3{color:var(--text-tertiary);font-size:1.5rem;font-weight:700;margin:1.5rem 0 .75rem}.empty-state p{color:var(--text-tertiary);line-height:1.8;max-width:500px}@media (max-width:1024px){.backtest-config{grid-template-columns:1fr}.performance-cards{grid-template-columns:repeat(2,1fr)}.comparison-summary{grid-template-columns:1fr}}@media (max-width:768px){.backtesting-view{padding:1rem}.backtest-config{padding:1.5rem}.performance-cards{grid-template-columns:1fr}.strategy-buttons{flex-direction:column}.backtest-table{font-size:.8rem}.backtest-table td,.backtest-table th{padding:.75rem .5rem}.results-table{overflow-x:auto}}.voting-timeline-container{background:var(--card-bg);border:2px solid var(--border-color);border-radius:.75rem;margin-bottom:2rem;padding:2rem}.timeline-header{align-items:flex-start;border-bottom:2px solid var(--border-color);display:flex;justify-content:space-between;margin-bottom:1.5rem;padding-bottom:1rem}.header-left h3{color:var(--text-primary);font-size:1.5rem;font-weight:700;margin:0 0 .5rem}.header-subtitle{color:var(--text-tertiary);font-size:.95rem}.header-controls{display:flex;gap:.75rem}.export-btn,.info-btn{align-items:center;background:var(--card-bg);border:2px solid var(--border-color);border-radius:.5rem;color:var(--text-primary);cursor:pointer;display:flex;font-size:.875rem;font-weight:600;gap:.5rem;padding:.625rem 1rem;transition:all .2s}.export-btn:hover,.info-btn:hover{background:var(--bg-secondary);border-color:var(--primary-color);color:var(--primary-color)}.info-panel{background:linear-gradient(135deg,var(--primary-light) 0,var(--bg-tertiary) 100%);border-left:4px solid var(--primary-color);border-radius:.5rem;margin-bottom:1.5rem}.info-panel h4{color:var(--text-primary);font-size:1.125rem;font-weight:700}.info-panel ul{color:var(--text-secondary);margin:0 0 1rem}.info-note,.info-panel li{line-height:1.6}.info-note{background:var(--card-bg);border-radius:.375rem;color:var(--text-tertiary);font-size:.875rem;margin:0;padding:.75rem}.combination-selector{align-items:center;background:var(--bg-secondary);border-radius:.5rem;display:flex;gap:1rem;margin-bottom:1.5rem;padding:1rem}.combination-selector label{color:var(--text-primary);font-size:.95rem;font-weight:600}.combination-selector select{background:var(--card-bg);border:2px solid var(--border-color);border-radius:.5rem;color:var(--text-primary);cursor:pointer;flex:1 1;font-size:.95rem;padding:.625rem 1rem;transition:all .2s}.combination-selector select:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px var(--info-light);outline:none}.stats-cards{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(3,1fr);margin-bottom:2rem}.stat-card{align-items:center;background:var(--card-bg);border:2px solid var(--border-color);display:flex;gap:1.25rem}.stat-card:hover{box-shadow:0 10px 25px var(--card-shadow-md);transform:translateY(-3px)}.stat-card.buy-stat{background:linear-gradient(135deg,var(--success-light) 0,var(--card-bg) 100%);border-color:var(--success-color)}.stat-card.sell-stat{background:linear-gradient(135deg,var(--error-light) 0,var(--card-bg) 100%);border-color:var(--error-color)}.stat-card.hold-stat{background:linear-gradient(135deg,var(--bg-tertiary) 0,var(--card-bg) 100%);border-color:var(--text-tertiary)}.stat-icon{align-items:center;border-radius:.75rem;color:var(--text-inverse);display:flex;flex-shrink:0;height:56px;justify-content:center;width:56px}.buy-stat .stat-icon{background:linear-gradient(135deg,var(--success-color) 0,var(--success-hover) 100%)}.sell-stat .stat-icon{background:linear-gradient(135deg,var(--error-color) 0,var(--error-hover) 100%)}.hold-stat .stat-icon{background:linear-gradient(135deg,var(--text-tertiary) 0,var(--text-secondary) 100%)}.stat-content{display:flex;flex:1 1;flex-direction:column}.stat-label{color:var(--text-tertiary);margin-bottom:.25rem}.stat-value{margin-bottom:.125rem}.stat-percentage{color:var(--text-tertiary);font-size:.875rem;font-weight:600}.chart-section{border:1px solid var(--border-color)}.chart-section h4{color:var(--text-primary);font-size:1.125rem;font-weight:700;margin:0 0 1rem}.section-subtitle{color:var(--text-tertiary);font-size:.875rem;margin:0 0 1rem}.voting-tooltip{background:var(--card-bg);border:2px solid var(--border-color);border-radius:.5rem;box-shadow:0 10px 25px var(--card-shadow-lg);min-width:250px;padding:1rem}.tooltip-date{border-bottom:1px solid var(--border-color);color:var(--text-primary);font-size:.875rem;font-weight:700;margin:0 0 .75rem;padding-bottom:.5rem}.tooltip-price{color:var(--primary-color);font-size:.875rem;font-weight:600;margin-bottom:.75rem}.tooltip-votes{border-bottom:1px solid var(--border-color);margin-bottom:.75rem;padding-bottom:.75rem}.vote-row{align-items:center;display:flex;font-size:.875rem;gap:.5rem;margin-bottom:.375rem}.vote-row:last-child{margin-bottom:0}.vote-row.buy{color:var(--success-color)}.vote-row.sell{color:var(--error-color)}.vote-row.hold{color:var(--text-tertiary)}.tooltip-result{align-items:center;display:flex;font-size:.875rem;font-weight:600;gap:.5rem;margin-bottom:.75rem}.signal-badge{font-size:.75rem;font-weight:700;padding:.25rem .625rem}.signal-badge.buy{background:var(--success-light);color:var(--success-color)}.signal-badge.sell{background:var(--error-light);color:var(--error-color)}.signal-badge.hold{background:var(--bg-tertiary);color:var(--text-secondary)}.tooltip-individual{border-top:1px solid #e5e7eb;padding-top:.75rem}.tooltip-individual strong{color:var(--text-primary);display:block;font-size:.875rem;margin-bottom:.5rem}.indicator-signal{align-items:center;display:flex;font-size:.8rem;justify-content:space-between;margin-bottom:.375rem}.indicator-name{color:var(--text-tertiary);font-weight:600}.signal-mini{border-radius:999px;font-size:.7rem;font-weight:700;padding:.125rem .5rem}.signal-mini.buy{background:var(--success-light);color:var(--success-color)}.signal-mini.sell{background:var(--error-light);color:var(--error-color)}.signal-mini.hold{background:var(--bg-tertiary);color:var(--text-secondary)}.consensus-section{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:.5rem;padding:1.5rem}.consensus-section h4{color:var(--text-primary);font-size:1.125rem;font-weight:700;margin:0 0 .5rem}.consensus-chart{align-items:flex-end;display:flex;gap:.25rem;height:150px;margin-bottom:1rem;padding:1rem 0}.consensus-bar-wrapper{align-items:center;display:flex;flex:1 1;flex-direction:column;height:100%;position:relative}.consensus-bar{border-radius:2px 2px 0 0;cursor:pointer;min-height:2px;transition:all .3s;width:100%}.consensus-bar:hover{opacity:.8;transform:scaleY(1.05)}.consensus-label{bottom:-20px;color:var(--text-tertiary);font-size:.7rem;position:absolute;transform:rotate(-45deg);white-space:nowrap}.consensus-legend{display:flex;flex-wrap:wrap;gap:1.5rem;justify-content:center;margin-top:2rem}.legend-item{color:var(--text-tertiary);font-size:.875rem}.legend-color{border-radius:2px;height:12px;width:20px}.voting-timeline-error{align-items:center;color:var(--text-tertiary);display:flex;flex-direction:column;justify-content:center;padding:4rem 2rem;text-align:center}.voting-timeline-error p{color:var(--text-tertiary);font-size:1.125rem;font-weight:600;margin:1rem 0 .5rem}.error-hint{color:var(--text-tertiary);font-size:.95rem;font-weight:400}@media (max-width:1024px){.stats-cards{grid-template-columns:1fr}.timeline-header{flex-direction:column;gap:1rem}.header-controls{justify-content:flex-end;width:100%}}@media (max-width:768px){.stat-card,.voting-timeline-container{padding:1rem}.stat-icon{height:48px;width:48px}.stat-value{font-size:1.5rem}.chart-section{padding:1rem}.consensus-chart{height:100px}}.guide-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:var(--overlay-dark);bottom:0;display:flex;justify-content:center;left:0;padding:2rem;position:fixed;right:0;top:0;z-index:9999}.guide-modal{background:var(--card-bg);border-radius:1rem;box-shadow:0 25px 50px var(--card-shadow-lg);display:flex;flex-direction:column;max-height:90vh;max-width:1200px;overflow:hidden;width:100%}.guide-header{align-items:center;background:var(--gradient-primary);color:var(--text-inverse);display:flex;justify-content:space-between;padding:1.5rem 2rem}.header-title{gap:1rem}.header-title h2{font-size:1.75rem;font-weight:700}.close-btn{align-items:center;background:var(--text-inverse-alpha-02);border-radius:.5rem;color:var(--text-inverse);display:flex;justify-content:center;padding:.5rem;transition:all .2s}.close-btn:hover{background:var(--text-inverse-alpha-03);transform:scale(1.1)}.guide-body{display:flex;flex:1 1;overflow:hidden}.guide-sidebar{background:var(--bg-secondary);border-right:1px solid var(--border-color);display:flex;flex-direction:column;gap:.5rem;overflow-y:auto;padding:1rem;width:240px}.sidebar-btn{align-items:center;background:var(--card-bg);border:2px solid var(--border-color);border-radius:.5rem;color:var(--text-tertiary);cursor:pointer;display:flex;font-size:.95rem;font-weight:600;gap:.75rem;padding:.875rem 1rem;text-align:left;transition:all .2s}.sidebar-btn:hover{background:var(--bg-tertiary);border-color:var(--primary-color);color:var(--primary-color)}.sidebar-btn.active{background:var(--gradient-primary);border-color:var(--primary-color);color:var(--text-inverse)}.guide-main{flex:1 1;overflow-y:auto;padding:2rem}.section-icon{align-items:center;background:var(--gradient-primary);border-radius:1rem;color:var(--text-inverse);display:flex;height:64px;justify-content:center;margin-bottom:1.5rem;width:64px}.guide-content h3{font-size:1.75rem;margin:0 0 1rem}.guide-content h3,.guide-content h4{color:var(--text-primary);font-weight:700}.guide-content h4{font-size:1.25rem;margin:1.5rem 0 1rem}.guide-content h5{color:var(--text-secondary);font-size:1.1rem;font-weight:700;margin:1rem 0 .5rem}.guide-content p{color:var(--text-secondary);font-size:1rem;line-height:1.7;margin:0 0 1rem}.guide-content ol,.guide-content ul{color:var(--text-secondary);line-height:1.8;margin:0 0 1rem;padding-left:1.5rem}.guide-content li{margin-bottom:.5rem}.info-box{background:linear-gradient(135deg,var(--primary-light) 0,var(--bg-secondary) 100%);border-left:4px solid var(--primary-color);border-radius:.5rem;margin:1.5rem 0;padding:1.5rem}.info-box.warning{align-items:flex-start;background:linear-gradient(135deg,var(--warning-light) 0,var(--warning-light) 100%);border-left-color:var(--warning-color);display:flex;gap:1rem}.info-box strong{color:var(--text-primary);display:block;font-size:1.1rem;margin-bottom:.5rem}.info-box ul{margin:.5rem 0 0}.info-box li{margin-bottom:.375rem}.rule-section{margin:2rem 0}.rule-box{background:var(--card-bg);border:2px solid var(--border-color);border-radius:.75rem;margin-top:1rem;padding:1.5rem}.examples{flex-direction:column;margin:1rem 0}.example,.examples{display:flex;gap:.75rem}.example{align-items:center;border-radius:.5rem;font-size:.95rem;padding:.875rem 1rem}.example.buy{background:var(--success-light);color:var(--success-color)}.example.sell{background:var(--error-light);color:var(--error-color)}.example.hold{background:var(--bg-tertiary);color:var(--text-secondary)}.example-note{background:var(--bg-secondary);border-radius:.5rem;font-size:.9rem;line-height:1.6;margin-top:1rem;padding:1rem}.example-note strong.buy{color:var(--success-color);font-weight:700}.example-note strong.sell{color:var(--error-color);font-weight:700}.example-note strong.hold{color:var(--text-tertiary);font-weight:700}.rule-section.tie-breaking .rule-box{background:linear-gradient(135deg,var(--warning-light) 0,var(--card-bg) 100%);border-color:var(--warning-color)}.note{background:var(--bg-secondary);border-left:3px solid var(--primary-color);border-radius:.375rem;color:var(--text-secondary);font-size:.9rem;margin-top:1rem;padding:.75rem}.examples-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(2,1fr);margin:1.5rem 0}.example-card{background:var(--card-bg);border:2px solid var(--border-color);border-radius:.75rem;padding:1.5rem;text-align:center}.example-card h5{color:var(--text-primary);font-size:1.1rem;font-weight:700;margin:.75rem 0 .5rem}.example-card p{color:var(--text-tertiary);font-size:.9rem;margin:0}.code-example{background:var(--text-primary-dark);border-radius:.75rem;margin:1.5rem 0;padding:1.5rem}.code-example h5{color:var(--success-color);margin:0 0 1rem}.code-example pre{color:var(--border-color);font-family:Courier New,monospace;font-size:.9rem;line-height:1.8;margin:0;white-space:pre-wrap}.scenario-card{background:var(--card-bg);border:2px solid var(--border-color);border-radius:.75rem;margin:2rem 0;padding:1.5rem}.scenario-card h4{color:var(--text-primary);margin:0 0 1rem}.indicator-votes{display:flex;flex-direction:column;gap:.75rem;margin:1rem 0}.vote{border-radius:.5rem;font-size:.95rem;font-weight:600;padding:.875rem 1rem}.vote.buy{background:var(--success-light);border-left:4px solid var(--success-color);color:var(--success-color)}.vote.sell{background:var(--error-light);border-left:4px solid var(--error-color);color:var(--error-color)}.vote.hold{background:var(--bg-tertiary);border-left:4px solid var(--text-tertiary);color:var(--text-secondary)}.vote.neutral{background:var(--primary-light);border-left:4px solid var(--primary-color);color:var(--primary-hover)}.result{border-radius:.75rem;margin-top:1.5rem;padding:1.5rem;text-align:center}.result strong{display:block;font-size:1.25rem;margin-bottom:.5rem}.result p{font-size:.95rem;margin:0}.buy-result{background:linear-gradient(135deg,var(--success-light) 0,var(--success-light) 100%);border:3px solid var(--success-color);color:var(--success-color)}.sell-result{background:linear-gradient(135deg,var(--error-light) 0,var(--error-light) 100%);border:3px solid var(--error-color);color:var(--error-color)}.hold-result{background:linear-gradient(135deg,var(--bg-tertiary) 0,var(--bg-secondary) 100%);border:3px solid var(--text-tertiary);color:var(--text-primary)}.tip-section{margin:2rem 0}.tips-list{margin:1rem 0;padding-left:1.5rem}.tips-list li{line-height:1.6;margin-bottom:1rem}.tips-list.danger li strong{color:var(--error-color)}.best-combo{margin:2rem 0}.combo-card{background:var(--card-bg);border:2px solid var(--border-color);border-left:4px solid var(--primary-color);border-radius:.75rem;margin-bottom:1rem;padding:1.5rem}.combo-card h5{color:var(--text-primary);font-size:1.1rem;font-weight:700;margin:0 0 .5rem}.combo-card p{color:var(--primary-color);font-family:Courier New,monospace;font-weight:600;margin:0 0 .5rem}.combo-note{color:var(--text-tertiary);display:block;font-size:.875rem;font-style:italic}.guide-footer{background:var(--bg-secondary);border-top:1px solid var(--border-color);padding:1rem 2rem;text-align:center}.guide-footer p{color:var(--text-tertiary);font-size:.95rem;margin:0}@media (max-width:1024px){.guide-modal{max-width:95%}.guide-sidebar{width:200px}.guide-main{padding:1.5rem}}@media (max-width:768px){.guide-overlay{padding:1rem}.guide-modal{max-height:95vh}.guide-body{flex-direction:column}.guide-sidebar{border-bottom:1px solid var(--border-color);border-right:none;flex-direction:row;overflow-x:auto;width:100%}.sidebar-btn{flex-shrink:0}.guide-main{padding:1rem}.examples-grid{grid-template-columns:1fr}.header-title h2{font-size:1.25rem}}.screener-tab{margin:0 auto;max-width:1400px;padding:2rem}.screener-header{align-items:flex-start;border-bottom:2px solid #e5e7eb;display:flex;justify-content:space-between;margin-bottom:2rem;padding-bottom:1.5rem}.screener-header h2{color:#1f2937;font-size:1.75rem;font-weight:700;margin:0 0 .5rem}.screener-subtitle{color:#6b7280;font-size:.95rem;margin:0}.screener-controls{align-items:center;display:flex;gap:1.5rem}.exchange-info,.timeframe-info{display:flex;flex-direction:column;gap:.25rem}.exchange-info .label,.timeframe-info .label{color:#6b7280;font-size:.75rem;letter-spacing:.05em;text-transform:uppercase}.exchange-info .value,.timeframe-info .value{color:#667eea;font-size:1rem;font-weight:700}.screener-tabs{border-bottom:2px solid #e5e7eb;display:flex;gap:1rem;margin-bottom:2rem}.tab-button{align-items:center;background:none;border:none;border-bottom:3px solid #0000;color:#6b7280;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:.5rem;margin-bottom:-2px;padding:1rem 1.5rem;transition:all .3s}.tab-button:hover{background:#667eea0d;color:#667eea}.tab-button.active{border-bottom-color:#667eea;color:#667eea}.category-filter{margin-bottom:2rem}.category-filter h4{color:#374151;font-size:.95rem;font-weight:600;margin-bottom:1rem}.category-buttons{display:flex;flex-wrap:wrap;gap:.75rem}.category-btn{align-items:center;background:#fff;border:2px solid #e5e7eb;border-radius:.5rem;color:#374151;cursor:pointer;display:flex;font-size:.9rem;font-weight:500;gap:.5rem;padding:.625rem 1.25rem;transition:all .3s}.category-btn:hover{background:#667eea0d;border-color:#667eea;box-shadow:0 4px 12px #667eea26;transform:translateY(-2px)}.category-btn.active{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea;box-shadow:0 4px 12px #667eea4d;color:#fff}.category-emoji{font-size:1.2rem}.screener-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));margin-bottom:2rem}.screener-card{background:#fff;border:2px solid #e5e7eb;border-radius:.75rem;cursor:pointer;padding:1.5rem;transition:all .3s}.screener-card:hover{border-color:#667eea;box-shadow:0 8px 20px #667eea26;transform:translateY(-4px)}.screener-card.custom{background:linear-gradient(135deg,#667eea0d,#764ba20d)}.screener-card-header{display:flex;gap:1rem;margin-bottom:1rem}.screener-icon{flex-shrink:0;font-size:2rem}.screener-info{flex:1 1}.screener-info h4{color:#1f2937;font-size:1.1rem;font-weight:700;margin:0 0 .5rem}.screener-description{color:#6b7280;font-size:.875rem;line-height:1.5;margin:0}.screener-card-footer{align-items:center;border-top:1px solid #e5e7eb;display:flex;justify-content:space-between;margin-top:1rem;padding-top:1rem}.screener-category{background:#f3f4f6;border-radius:.375rem;color:#4b5563;font-size:.8rem;font-weight:500;padding:.25rem .75rem;text-transform:capitalize}.run-screener-btn{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:.5rem;color:#fff;cursor:pointer;display:flex;font-size:.9rem;font-weight:600;gap:.5rem;padding:.625rem 1.25rem;transition:all .3s}.run-screener-btn:hover:not(:disabled){box-shadow:0 4px 12px #667eea66;transform:translateY(-2px)}.run-screener-btn:disabled{cursor:not-allowed;opacity:.6}.run-screener-btn .spin{animation:spin 1s linear infinite}.screener-results{background:#fff;border:2px solid #e5e7eb;border-radius:.75rem;margin-top:3rem;padding:2rem}.results-header{border-bottom:2px solid #e5e7eb;margin-bottom:1.5rem;padding-bottom:1rem}.results-header h3{color:#1f2937;font-size:1.5rem;margin:0 0 1rem}.results-stats{display:flex;flex-wrap:wrap;gap:2rem}.stat-item{color:#6b7280;font-size:.9rem}.stat-item strong{color:#667eea;font-weight:700}.no-results{color:#6b7280;padding:3rem 2rem;text-align:center}.no-results svg{color:#d1d5db;margin-bottom:1rem}.no-results p{font-size:1rem;margin:.5rem 0}.no-results .hint{color:#9ca3af;font-size:.875rem}.results-table-container{overflow-x:auto}.results-table{border-collapse:collapse;width:100%}.results-table thead{background:#f9fafb}.results-table th{border-bottom:2px solid #e5e7eb;color:#374151;font-size:.875rem;font-weight:600;padding:1rem;text-align:left}.results-table td{border-bottom:1px solid #e5e7eb;color:#4b5563;font-size:.9rem;padding:1rem}.results-table tbody tr:hover{background:#f9fafb}.ticker-cell{color:#1f2937;font-weight:700}.price-cell{color:#059669;font-family:Courier New,monospace;font-weight:600}.indicators-cell{color:#6b7280;font-size:.8rem}.analyze-btn-small{background:#667eea;border:none;border-radius:.375rem;color:#fff;cursor:pointer;font-size:.8rem;font-weight:600;padding:.375rem .875rem;transition:all .2s}.analyze-btn-small:hover{background:#5568d3;transform:translateY(-1px)}.custom-screeners{min-height:400px}.custom-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:2rem}.custom-header h3{color:#1f2937;font-size:1.25rem;margin:0}.create-screener-btn{align-items:center;background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:.5rem;color:#fff;cursor:pointer;display:flex;font-size:.9rem;font-weight:600;gap:.5rem;padding:.75rem 1.25rem;transition:all .3s}.create-screener-btn:hover{box-shadow:0 4px 12px #10b9814d;transform:translateY(-2px)}.no-screeners{color:#6b7280;padding:4rem 2rem;text-align:center}.no-screeners svg{color:#d1d5db;margin-bottom:1.5rem}.no-screeners p{font-size:1.1rem;margin:.5rem 0 2rem}.create-screener-btn-large{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:.5rem;color:#fff;cursor:pointer;display:inline-flex;font-size:1rem;font-weight:600;gap:.75rem;padding:1rem 2rem;transition:all .3s}.create-screener-btn-large:hover{box-shadow:0 6px 16px #667eea66;transform:translateY(-2px)}.screener-actions{display:flex;gap:.5rem}.icon-btn{background:#f3f4f6;border:none;border-radius:.375rem;color:#6b7280;cursor:pointer;padding:.5rem;transition:all .2s}.icon-btn:hover{background:#ef4444;color:#fff}.no-templates{color:#9ca3af;font-size:1rem;padding:3rem 2rem;text-align:center}@media (max-width:768px){.screener-tab{padding:1rem}.screener-header{flex-direction:column;gap:1rem}.screener-controls{justify-content:space-around;width:100%}.screener-grid{grid-template-columns:1fr}.results-table{font-size:.8rem}.results-table td,.results-table th{padding:.75rem .5rem}}.language-switcher{position:relative}.language-switcher-button{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:8px;color:#64748b;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:6px;padding:8px 12px;transition:all .2s ease}.language-switcher-button:hover{background:#f1f5f9;border-color:#3b82f6;color:#3b82f6}.language-code{font-size:12px;font-weight:600}.language-dropdown{background:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026;min-width:180px;overflow:hidden;position:absolute;right:0;top:calc(100% + 8px);z-index:1000}.language-option{align-items:center;background:none;border:none;color:#333;cursor:pointer;display:flex;gap:10px;padding:12px 16px;text-align:left;transition:background .2s ease;width:100%}.language-option:hover{background:#f5f5f5}.language-option.active{background:#e3f2fd;font-weight:600}.language-flag{font-size:20px}.language-name{flex:1 1;font-size:14px}.language-check{color:#2196f3;font-weight:700}@media (prefers-color-scheme:dark){.language-dropdown{background:#1e1e1e;box-shadow:0 4px 12px #0000004d}.language-option{color:#fff}.language-option:hover{background:#2a2a2a}.language-option.active{background:#1e3a5f}}.technical-dashboard-new{background:#f9fafb;display:flex;height:100vh;left:0;margin:0;max-width:100%;overflow:hidden;padding:0;position:relative;right:0;width:100vw}.dashboard-sidebar{background:#fff;box-shadow:2px 0 8px #0000000d;flex-shrink:0;height:100%;overflow:visible;position:relative;z-index:10}.dashboard-main{display:flex;flex:1 1;flex-direction:column;min-width:0;overflow:hidden;width:0}.dashboard-header{align-items:center;background:#fff;border-bottom:2px solid #e5e7eb;display:flex;justify-content:space-between;padding:1.5rem 2rem}.dashboard-header h1{align-items:center;color:#1f2937;display:flex;font-size:1.5rem;font-weight:700;gap:.75rem;margin:0}.header-subtitle{color:#6b7280;margin:.5rem 0 0}.header-actions{gap:1rem}.guide-btn{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:.625rem;color:#fff;cursor:pointer;display:flex;font-size:.95rem;font-weight:600;gap:.625rem;padding:.75rem 1.5rem;transition:all .2s}.guide-btn:hover{box-shadow:0 8px 20px #667eea4d;transform:translateY(-2px)}.guide-btn:active{transform:translateY(0)}.tabs-container{background:#fff;border-bottom:1px solid #e5e7eb;padding:0 2rem}.tabs{overflow-x:auto}.tab,.tabs{display:flex;gap:.5rem}.tab{align-items:center;background:#0000;border:none;border-bottom:3px solid #0000;color:#6b7280;cursor:pointer;font-size:.95rem;font-weight:500;padding:1rem 1.5rem;position:relative;transition:all .2s;white-space:nowrap}.tab.active,.tab:hover{background:#667eea0d;color:#667eea}.tab.active{border-bottom-color:#667eea}.tab-badge{background:#667eea;font-size:.75rem;font-weight:600}.tab-badge,.tab-badge-new{border-radius:999px;color:#fff;padding:.125rem .5rem}.tab-badge-new{animation:pulse-badge 2s ease-in-out infinite;background:linear-gradient(135deg,#10b981,#059669);font-size:.65rem;font-weight:700;margin-left:.5rem}@keyframes pulse-badge{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.05)}}.tab-content{flex:1 1;overflow-y:auto;padding:2rem;position:relative}.loading-overlay{align-items:center;background:#fffffff2;bottom:0;display:flex;flex-direction:column;gap:1rem;justify-content:center;left:0;position:absolute;right:0;top:0;z-index:100}.loading-overlay .spin{animation:spin 1s linear infinite;color:#667eea}.loading-overlay p{color:#6b7280;font-size:1rem;font-weight:500}.no-data{flex-direction:column;padding:4rem 2rem}.no-data svg{margin-bottom:1rem}.no-data p{color:#6b7280;font-size:1.1rem;margin-bottom:.5rem}.no-data .text-sm{color:#9ca3af;font-size:.9rem}.overview-content{max-width:100%;width:100%}.overview-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:2rem}.overview-header h2{color:#1f2937;font-size:1.5rem;font-weight:700;margin:0}.overview-subtitle{color:#6b7280;font-size:.9rem;margin:.5rem 0 0}.export-btn{background:#667eea;border-radius:.375rem;font-size:.875rem;padding:.625rem 1rem;transition:background .2s}.export-btn:hover{background:#5568d3}.stats-grid{grid-gap:1.5rem;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:2rem}.stat-card{background:#fff;border:1px solid #e5e7eb;border-radius:.75rem;box-shadow:0 1px 3px #0000000d;padding:1.5rem;transition:all .2s}.stat-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.stat-label{font-weight:500;margin-bottom:.5rem}.stat-value{font-size:1.75rem}.chart-section{background:#fff;border:1px solid #e5e7eb;border-radius:.75rem;box-shadow:0 1px 3px #0000000d;margin-bottom:2rem}.chart-section h3{color:#374151;font-size:1.1rem;font-weight:600;margin:0 0 1.5rem}.individual-analysis-content h2{color:#1f2937;font-size:1.5rem;font-weight:700;margin:0 0 .5rem}.section-subtitle{color:#6b7280;font-size:.95rem;margin:0 0 2rem}.indicator-analysis-card{background:#fff;border:1px solid #e5e7eb;border-radius:.75rem;box-shadow:0 1px 3px #0000000d;margin-bottom:2rem;padding:1.5rem}.indicator-analysis-card h3{border-bottom:2px solid #e5e7eb;color:#374151;font-size:1.2rem;font-weight:600;margin:0 0 1.5rem;padding-bottom:.75rem}.combined-analysis-content h2{color:#1f2937;font-size:1.5rem;font-weight:700;margin:0 0 .5rem}.info-panel{background:linear-gradient(135deg,#667eea15,#764ba215);border:1px solid #667eea;border-radius:.75rem;margin-bottom:2rem;padding:1.5rem}.info-panel h4{color:#667eea;font-size:1.1rem;font-weight:600;margin:0 0 1rem}.info-panel ul{list-style:disc;margin:0;padding-left:1.5rem}.info-panel li{color:#4b5563;font-size:.95rem;margin-bottom:.5rem}.info-panel li strong{color:#1f2937}.combinations-table-section{background:#fff;border:1px solid #e5e7eb;border-radius:.75rem;box-shadow:0 1px 3px #0000000d;padding:1.5rem}.combinations-table-section h3{color:#374151;font-size:1.2rem;font-weight:600;margin:0 0 1.5rem}.table-wrapper{border:1px solid #e5e7eb;border-radius:.5rem;overflow-x:auto}.combinations-table{border-collapse:collapse;font-size:.9rem;width:100%}.combinations-table thead{background:#f9fafb}.combinations-table th{border-bottom:2px solid #e5e7eb;color:#374151;font-weight:600;padding:.875rem 1rem;text-align:left;white-space:nowrap}.combinations-table td{border-bottom:1px solid #f3f4f6;color:#4b5563;padding:.875rem 1rem}.combinations-table tbody tr:hover{background:#f9fafb}.combo-name{color:#1f2937;font-weight:600}.indicators-list{color:#6b7280;font-size:.85rem}.buy-count{color:#10b981;font-weight:600}.sell-count{color:#ef4444;font-weight:600}.hold-count{color:#6b7280;font-weight:600}.signal-badge{border-radius:999px;font-size:.8rem;font-weight:600;padding:.25rem .75rem;text-transform:uppercase}.signal-badge.buy{background:#d1fae5;color:#065f46}.signal-badge.sell{background:#fee2e2;color:#991b1b}.signal-badge.hold{background:#f3f4f6;color:#4b5563}.backtesting-content{min-height:400px}.info-message{background:#f9fafb;border:1px solid #e5e7eb;border-radius:.5rem;color:#6b7280;padding:2rem;text-align:center}.info-message p{font-size:.95rem;margin:0}@media (max-width:1024px){.dashboard-sidebar{width:300px}.dashboard-header{padding:1rem 1.5rem}.dashboard-header h1{font-size:1.25rem}.tab-content{padding:1.5rem}}@media (max-width:768px){.technical-dashboard-new{flex-direction:column;height:auto}.dashboard-sidebar{border-bottom:2px solid #e5e7eb;border-right:none;max-height:60vh;width:100%}.dashboard-main{min-height:calc(100vh - 64px)}.dashboard-header{padding:1rem}.dashboard-header h1{font-size:1.1rem}.tabs-container{padding:0 1rem}.tab{font-size:.85rem;padding:.75rem 1rem}.tab-content{padding:1rem}.stats-grid{gap:1rem;grid-template-columns:1fr}.overview-header{flex-direction:column;gap:1rem}}.tab-content::-webkit-scrollbar,.table-wrapper::-webkit-scrollbar{height:8px;width:8px}.tab-content::-webkit-scrollbar-track,.table-wrapper::-webkit-scrollbar-track{background:#f1f1f1}.tab-content::-webkit-scrollbar-thumb,.table-wrapper::-webkit-scrollbar-thumb{background:#667eea;border-radius:4px}.tab-content::-webkit-scrollbar-thumb:hover,.table-wrapper::-webkit-scrollbar-thumb:hover{background:#5568d3}.portfolio-page{background:var(--bg-primary);min-height:100vh;padding:clamp(calc(1rem + 80px),calc(2vw + 80px),calc(2rem + 80px)) clamp(.75rem,2vw,2rem) clamp(1rem,2vw,2rem)}.portfolio-page .container{margin:0 auto;max-width:100%;padding:0 1.5rem;width:100%}.portfolio-header{align-items:flex-start;background:var(--card-bg);border:1px solid var(--card-border);border-radius:.75rem;box-shadow:0 2px 8px var(--card-shadow);display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:1.5rem;padding:1.25rem}.portfolio-header h1{color:var(--text-primary);flex:1 1;font-size:1.5rem;font-weight:600;margin:0;min-width:200px}.portfolio-actions{align-items:center!important;display:flex!important;flex-direction:row!important;flex-wrap:wrap!important;gap:.5rem!important;justify-content:flex-start!important;max-width:100%!important;width:100%!important}.portfolio-actions .btn{flex:0 0 auto!important;flex-grow:0!important;flex-shrink:0!important;font-size:.8125rem!important;max-width:none!important;min-width:auto!important;padding:.5rem .875rem!important;width:auto!important}.btn{align-items:center;border:none;border-radius:.5rem;cursor:pointer;display:flex;flex-shrink:0;font-size:.875rem;font-weight:500;gap:.375rem;padding:.5rem 1rem;transition:all .2s;white-space:nowrap}.portfolio-actions .btn svg{flex-shrink:0!important;height:14px!important;width:14px!important}.btn:disabled{cursor:not-allowed;opacity:.6}.btn-primary{background:var(--info-color)}.btn-primary:hover:not(:disabled){background:var(--primary-hover)}.btn-secondary{color:#fff}.btn-secondary,.btn-secondary:hover:not(:disabled){background:var(--text-tertiary)}.btn-danger{background:var(--error-color);color:#fff}.btn-danger:hover:not(:disabled){background:var(--error-color);opacity:.9}.btn-success{background:var(--success-color);color:#fff}.btn-success:hover:not(:disabled){background:var(--success-color);opacity:.9}.btn-warning{background:var(--warning-color);color:#fff}.btn-warning:hover:not(:disabled){background:var(--warning-color);opacity:.9}.btn-info{background:var(--info-color);color:#fff}.btn-info:hover:not(:disabled){background:var(--info-color);opacity:.9}.spinning{animation:spin 1s linear infinite}.year-filter{align-items:center;background:var(--card-bg);border-radius:.5rem;box-shadow:0 1px 3px var(--card-shadow);display:flex;gap:.5rem;margin-bottom:1.5rem;padding:.75rem 1rem}.year-filter label{color:var(--text-secondary);font-weight:500}.year-filter select{background:var(--card-bg);border:1px solid var(--border-color);border-radius:.375rem;color:var(--text-primary);font-size:.875rem;padding:.5rem}.portfolio-tabs{border-bottom:2px solid var(--border-color);display:flex;gap:.5rem;margin-bottom:1.5rem;overflow-x:auto}.portfolio-tabs button{align-items:center;background:none;border:none;border-bottom:2px solid #0000;color:var(--text-secondary);cursor:pointer;display:flex;font-weight:500;gap:.5rem;margin-bottom:-2px;padding:.75rem 1.5rem;transition:all .2s;white-space:nowrap}.portfolio-tabs button:hover{color:var(--primary-color)}.portfolio-tabs button.active{border-bottom-color:var(--primary-color);color:var(--primary-color)}.portfolio-content{background:var(--card-bg);border-radius:.5rem;box-shadow:0 1px 3px var(--card-shadow);padding:1.5rem}.dashboard-tab{display:flex;flex-direction:column;gap:2rem}.unit-info-section{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:.5rem;padding:1.5rem}.unit-info-section h2{color:var(--text-primary);font-size:1.25rem;margin:0 0 1rem}.unit-info-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.info-card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:.5rem;padding:1rem}.info-card label{color:var(--text-secondary);display:block;font-size:.75rem;font-weight:500;margin-bottom:.5rem;text-transform:uppercase}.info-value{font-size:1.5rem;font-weight:700}.info-value.positive{color:var(--success-color)}.info-value.negative{color:var(--error-color)}.portfolio-summary{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.summary-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:.5rem;padding:1.5rem}.summary-card h3{color:var(--text-secondary);font-size:.875rem;font-weight:500;margin:0 0 .5rem;text-transform:uppercase}.summary-value{align-items:center;color:var(--text-primary);display:flex;font-size:1.75rem;font-weight:700;gap:.5rem;margin:0}.summary-value.positive{color:var(--success-color)}.summary-value.negative{color:var(--error-color)}.portfolio-table-container{overflow-x:auto}.portfolio-table-container h2{color:var(--text-primary);font-size:1.25rem;margin:0 0 1rem}.portfolio-table{border-collapse:collapse;font-size:.875rem;width:100%}.portfolio-table th{background:var(--bg-secondary);border-bottom:2px solid var(--border-color);color:var(--text-primary);font-weight:600;padding:.75rem;text-align:left;white-space:nowrap}.portfolio-table td{border-bottom:1px solid var(--border-color);color:var(--text-secondary);padding:.75rem}.portfolio-table tbody tr:hover{background:var(--bg-secondary)}.portfolio-table .positive{color:var(--success-color);font-weight:600}.portfolio-table .negative{color:var(--error-color);font-weight:600}.transactions-tab h2{color:var(--text-primary);font-size:1.5rem;margin:0 0 1.5rem}.transaction-year-group{margin-bottom:2rem}.transaction-year-group h3{border-bottom:2px solid var(--border-color);color:var(--text-primary);font-size:1.25rem;margin:0 0 1rem;padding-bottom:.5rem}.transactions-table{border-collapse:collapse;font-size:.875rem;width:100%}.transactions-table th{background:var(--bg-secondary);border-bottom:2px solid var(--border-color);color:var(--text-primary);font-weight:600;padding:.75rem;text-align:left;white-space:nowrap}.transactions-table td{border-bottom:1px solid var(--border-color);color:var(--text-secondary);padding:.75rem}.transactions-table tbody tr:hover{background:var(--bg-secondary)}.badge{border-radius:9999px;font-weight:600;padding:.25rem .75rem}.badge-primary{background:var(--info-light);color:var(--info-color)}.badge-danger{background:var(--error-light);color:var(--error-color)}.action-buttons{display:flex;gap:.5rem}.btn-icon{align-items:center;border:none;border-radius:.375rem;cursor:pointer;display:flex;justify-content:center;padding:.375rem;transition:all .2s}.btn-edit{color:var(--info-color)}.btn-edit,.btn-edit:hover{background:var(--info-light)}.btn-edit:hover{opacity:.8}.btn-delete{background:var(--error-light);color:var(--error-color)}.btn-delete:hover{background:var(--error-light);opacity:.8}.mutasi-tab h2{color:var(--text-primary);font-size:1.5rem;margin:0 0 1.5rem}.mutasi-table{border-collapse:collapse;font-size:.875rem;width:100%}.mutasi-table th{background:var(--bg-secondary);border-bottom:2px solid var(--border-color);color:var(--text-primary);font-weight:600;padding:.75rem;text-align:left;white-space:nowrap}.mutasi-table td{border-bottom:1px solid var(--border-color);color:var(--text-secondary);padding:.75rem}.mutasi-table tbody tr:hover{background:var(--bg-secondary)}.historis-tab h2{color:var(--text-primary);font-size:1.5rem;margin:0 0 1.5rem}.historis-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:2rem}.historis-header h2{margin:0}.chart-section{background:var(--bg-secondary);border-radius:.5rem;margin-bottom:3rem;padding:1.5rem}.chart-section h3{color:var(--text-primary);font-size:1.125rem;margin:0 0 1rem}.historis-table-section{margin-top:2rem}.historis-table-section h3{color:var(--text-primary);font-size:1.125rem;margin:0 0 1rem}.historis-table{border-collapse:collapse;font-size:.875rem;width:100%}.historis-table th{background:var(--bg-secondary);border-bottom:2px solid var(--border-color);color:var(--text-primary);font-weight:600;padding:.75rem;text-align:left;white-space:nowrap}.historis-table td{border-bottom:1px solid var(--border-color);color:var(--text-secondary);padding:.75rem}.historis-table tbody tr:hover{background:var(--bg-secondary)}.tutup-buku-tab h2{color:var(--text-primary);font-size:1.5rem;margin:0 0 1.5rem}.tutup-buku-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.5rem}.tutup-buku-table{border-collapse:collapse;font-size:.875rem;width:100%}.tutup-buku-table th{background:var(--bg-secondary);border-bottom:2px solid var(--border-color);color:var(--text-primary);font-weight:600;padding:.75rem;text-align:left;white-space:nowrap}.tutup-buku-table td{border-bottom:1px solid var(--border-color);color:var(--text-secondary);padding:.75rem}.tutup-buku-table tbody tr:hover{background:var(--bg-secondary)}.modal-overlay{background:var(--overlay-dark)}.modal-content{border-radius:.5rem;box-shadow:0 20px 25px -5px var(--card-shadow-hover);max-width:500px}.modal-content h2{font-size:1.5rem}.form-group label{font-size:.875rem}.form-group input,.form-group select{background:var(--card-bg);border:1px solid var(--border-color);border-radius:.375rem;font-size:.875rem;transition:border-color .2s}.form-group input:focus,.form-group select:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px var(--primary-light)}.form-group small{color:var(--text-secondary);display:block;font-size:.75rem;margin-top:.25rem}.form-group .info-text{background:var(--bg-secondary);border-radius:.375rem;color:var(--text-primary);font-weight:600;padding:.75rem}.modal-actions{gap:.5rem}.modal-actions .btn{box-sizing:border-box!important;flex:0 0 auto!important;max-width:none!important;min-width:auto!important;padding:.625rem 1.25rem!important;white-space:nowrap!important;width:auto!important}.empty-state{color:var(--text-secondary);padding:3rem;text-align:center}.empty-state p{font-size:1rem;margin:0}.loading{color:var(--text-secondary);font-size:1.125rem;padding:3rem}.error,.loading{text-align:center}.error{background:var(--error-light);border-radius:.5rem;color:var(--error-color);margin:2rem 0;padding:2rem}@media (max-width:1024px){.portfolio-page{padding:clamp(calc(1rem + 80px),calc(1.5vw + 80px),calc(1.5rem + 80px)) clamp(.75rem,1.5vw,1.5rem) clamp(1rem,1.5vw,1.5rem)}.portfolio-header{padding:clamp(1rem,2vw,1.25rem)}.portfolio-content{padding:clamp(1rem,2vw,1.5rem)}}@media (max-width:768px){.portfolio-page{padding:clamp(calc(.75rem + 80px),calc(2vw + 80px),calc(1rem + 80px)) clamp(.5rem,2vw,1rem) clamp(.75rem,2vw,1rem)}.portfolio-header{align-items:stretch;flex-direction:column}.portfolio-actions{flex-direction:row!important;flex-wrap:wrap;gap:.375rem;justify-content:flex-start;width:100%}.portfolio-actions .btn{flex:0 0 auto;font-size:.75rem;gap:.25rem;justify-content:center;max-width:none;min-width:auto;padding:.4375rem .75rem;width:auto}.portfolio-actions .btn svg{height:13px;width:13px}.portfolio-tabs{gap:.25rem}.portfolio-tabs button{font-size:.75rem;padding:.5rem 1rem}.portfolio-summary,.unit-info-grid{grid-template-columns:1fr}.historis-table,.mutasi-table,.portfolio-table,.transactions-table,.tutup-buku-table{font-size:.75rem}.historis-table td,.historis-table th,.mutasi-table td,.mutasi-table th,.portfolio-table td,.portfolio-table th,.transactions-table td,.transactions-table th,.tutup-buku-table td,.tutup-buku-table th{padding:.5rem}.modal-content{margin:clamp(.5rem,2vw,1rem);max-width:calc(100vw - 2rem);padding:clamp(1rem,3vw,1.5rem)}}@media (max-width:480px){.portfolio-page{padding:clamp(calc(.5rem + 80px),calc(2vw + 80px),calc(.75rem + 80px)) clamp(.5rem,2vw,.75rem) clamp(.5rem,2vw,.75rem)}.portfolio-header h1{font-size:clamp(1.25rem,5vw,1.5rem)}.portfolio-actions .btn{font-size:clamp(.7rem,2vw,.8125rem);padding:clamp(.375rem,1.5vw,.5rem) clamp(.5rem,2vw,.75rem)}.modal-content{margin:clamp(.25rem,2vw,.5rem);max-width:calc(100vw - 1rem);padding:clamp(.75rem,4vw,1rem)}}.historis-table-section,.mutasi-tab,.portfolio-table-container,.transactions-tab,.tutup-buku-tab{-webkit-overflow-scrolling:touch;border:1px solid #dee2e6;border-radius:8px;margin-bottom:1.5rem;overflow-x:auto;width:100%}table.historis-table,table.mutasi-table,table.portfolio-table,table.transactions-table,table.tutup-buku-table{border:none;margin-bottom:0;min-width:800px}@media (max-width:768px){.ai-assistant-wrapper{bottom:80px;right:20px}.ai-fab-btn{height:50px;width:50px}.ai-chat-window{bottom:70px;height:60vh;right:0;width:90vw}.portfolio-header{align-items:flex-start;flex-direction:column;gap:1rem}.portfolio-actions{grid-gap:.5rem;display:grid;gap:.5rem;grid-template-columns:1fr 1fr;width:100%}.portfolio-actions button{font-size:.8rem;justify-content:center;padding:.5rem;width:100%}.portfolio-tabs{-webkit-overflow-scrolling:touch;flex-wrap:nowrap;margin-bottom:1rem;overflow-x:auto;padding-bottom:5px}.portfolio-tabs button{flex-shrink:0;white-space:nowrap}.modal-content{max-height:85vh!important;padding:1rem!important;width:95%!important}.portfolio-summary,.unit-info-grid{gap:1rem;grid-template-columns:1fr}}.confirmation-modal-content{padding:1rem;text-align:center}.confirmation-icon{align-items:center;border-radius:50%;display:flex;height:80px;justify-content:center;margin:1rem auto 1.5rem;width:80px}.confirmation-icon.success{background-color:var(--success-light);color:var(--success-color)}.confirmation-icon.error{background-color:var(--error-light);color:var(--error-color)}.confirmation-message{margin-bottom:1.5rem}.confirmation-message p{color:var(--text-primary);font-size:1.1rem;line-height:1.6;margin:0}.confirmation-details{background-color:var(--bg-secondary);border-radius:8px;margin:1.5rem 0;padding:1rem;text-align:left}.confirmation-details h4{color:var(--text-primary);font-size:1rem;font-weight:600;margin:0 0 1rem}.details-grid{grid-gap:.75rem;display:grid;gap:.75rem}.detail-item{align-items:center;border-bottom:1px solid var(--border-color);justify-content:space-between;padding:.5rem 0}.detail-item:last-child{border-bottom:none}.detail-item.highlight{background-color:var(--info-light);border-bottom:none;border-radius:6px;margin-top:.5rem;padding:.75rem}.detail-label{font-size:.9rem}.detail-value{text-align:right}.confirmation-actions{display:flex;gap:1rem;justify-content:center;margin-top:1.5rem}.confirmation-actions .btn{border:none;border-radius:6px;cursor:pointer;font-size:1rem;font-weight:500;min-width:120px;padding:.75rem 1.5rem;transition:all .2s}.confirmation-actions .btn-success{background-color:var(--success-color);color:#fff}.confirmation-actions .btn-success:hover{background-color:var(--success-color);opacity:.9}.confirmation-actions .btn-danger{background-color:var(--error-color);color:#fff}.confirmation-actions .btn-danger:hover{background-color:var(--error-color);opacity:.9}@media (max-width:640px){.confirmation-modal-content{padding:.5rem}.confirmation-icon{height:60px;width:60px}.confirmation-icon svg{height:48px;width:48px}.confirmation-message p{font-size:1rem}.details-grid{gap:.5rem}.detail-item{align-items:flex-start;flex-direction:column;gap:.25rem}.detail-value{text-align:left}}.modern-tooltip-wrapper{align-items:center;cursor:help;display:inline-flex;position:relative}.modern-tooltip-content{animation:tooltipFadeIn .2s ease-out;background-color:#1e2329;border:1px solid #2a2e39;border-radius:6px;box-shadow:0 4px 15px #0006;color:#e1e3eb;font-size:.85rem;line-height:1.4;max-width:250px;min-width:150px;padding:8px 12px;pointer-events:none;position:absolute;text-align:center;white-space:nowrap;white-space:normal;z-index:1000}.tooltip-top{bottom:100%;margin-bottom:8px}.tooltip-bottom,.tooltip-top{left:50%;transform:translateX(-50%)}.tooltip-bottom{margin-top:8px;top:100%}.tooltip-left{margin-right:8px;right:100%}.tooltip-left,.tooltip-right{top:50%;transform:translateY(-50%)}.tooltip-right{left:100%;margin-left:8px}.tooltip-arrow{border-style:solid;height:0;position:absolute;width:0}.tooltip-top .tooltip-arrow{border-color:#2a2e39 #0000 #0000;border-width:6px 6px 0;bottom:-6px;left:50%;transform:translateX(-50%)}.tooltip-top .tooltip-arrow:after{border-color:#1e2329 #0000 #0000;border-style:solid;border-width:6px 6px 0;content:"";left:-6px;position:absolute;top:-7px}@keyframes tooltipFadeIn{0%{opacity:0;transform:translateX(-50%) translateY(5px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}.ai-assistant-wrapper{bottom:30px;font-family:Inter,sans-serif;position:fixed;right:30px;z-index:9999}.ai-fab-btn{align-items:center;background:linear-gradient(135deg,#2962ff,#1a237e);border:none;border-radius:50%;box-shadow:0 4px 20px #2962ff66;color:#fff;cursor:pointer;display:flex;height:60px;justify-content:center;position:relative;transition:all .3s cubic-bezier(.175,.885,.32,1.275);width:60px}.ai-fab-btn:hover{box-shadow:0 8px 30px #2962ff99;transform:scale(1.1)}.ai-fab-btn.active{background:#ef5350;transform:rotate(90deg)}.ai-badge{animation:pulse 2s infinite;background:#ef5350;border:2px solid #0b0e11;border-radius:10px;color:#fff;font-size:.65rem;font-weight:800;padding:2px 6px;position:absolute;right:-5px;top:-5px}.ai-chat-window{animation:slideUp .3s ease-out;background:#1e2329;border:1px solid #2a2e39;border-radius:16px;bottom:80px;box-shadow:0 10px 40px #00000080;display:flex;flex-direction:column;height:450px;overflow:hidden;position:absolute;right:0;transform-origin:bottom right;width:350px}.ai-chat-header{align-items:center;background:linear-gradient(90deg,#2962ff,#1565c0);color:#fff;display:flex;justify-content:space-between;padding:1rem}.ai-header-title{align-items:center;display:flex;font-weight:600;gap:.5rem}.ai-close-btn{background:#0000;border:none;color:#fff;cursor:pointer;opacity:.8}.ai-chat-body{align-items:center;background-image:radial-gradient(circle at 50% 50%,#2962ff0d 0,#0000 70%);display:flex;flex:1 1;flex-direction:column;justify-content:center;padding:2rem;text-align:center}.coming-soon-content h3{color:#fff;font-size:1.2rem;margin:1rem 0}.coming-soon-content p{color:#848e9c;font-size:.9rem;line-height:1.5;margin-bottom:2rem}.feature-preview-tags{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center}.feature-preview-tags span{background:#2962ff1a;border-radius:20px;color:#2962ff;font-size:.8rem;padding:4px 10px}.ai-chat-input-disabled{border-top:1px solid #2a2e39;display:flex;gap:.5rem;padding:1rem}.ai-chat-input-disabled input{background:#15191f;border:1px solid #2a2e39;border-radius:8px;color:#555;cursor:not-allowed;flex:1 1;padding:.8rem}.ai-chat-input-disabled button{background:#2a2e39;border:none;border-radius:8px;color:#555;cursor:not-allowed;width:40px}.csv-import-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000}.csv-import-modal{background:#fff;background:var(--bg-card,#fff);border-radius:16px;box-shadow:0 20px 60px #0000004d;display:flex;flex-direction:column;max-height:90vh;max-width:800px;overflow:hidden;width:100%}.import-header{background:#667eea;background:var(--primary-color,#667eea);border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color,#e5e7eb);color:#fff;justify-content:space-between;padding:1.25rem 1.5rem}.header-title,.import-header{align-items:center;display:flex}.header-title{gap:.75rem}.header-title h2{font-size:1.25rem;font-weight:600;margin:0}.import-header .close-btn{background:#fff3;border:none;border-radius:8px;color:#fff;cursor:pointer;padding:.5rem;transition:background .2s}.import-header .close-btn:hover{background:#ffffff4d}.import-steps{background:#f9fafb;background:var(--bg-secondary,#f9fafb);border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color,#e5e7eb);gap:.5rem;justify-content:center;padding:1.25rem}.import-steps,.step{align-items:center;display:flex}.step{flex-direction:column;gap:.25rem;opacity:.4;transition:opacity .3s}.step.active{opacity:1}.step.completed{opacity:.7}.step-icon{align-items:center;background:#fff;background:var(--bg-card,#fff);border:2px solid #e5e7eb;border:2px solid var(--border-color,#e5e7eb);border-radius:50%;color:#6b7280;color:var(--text-secondary,#6b7280);display:flex;height:36px;justify-content:center;width:36px}.step.active .step-icon{background:#667eea;border-color:#667eea;color:#fff}.step.completed .step-icon{background:#10b981;border-color:#10b981;color:#fff}.step span{color:#6b7280;color:var(--text-secondary,#6b7280);font-size:.75rem}.step.active span{color:#111827;color:var(--text-primary,#111827);font-weight:500}.step-line{background:#e5e7eb;background:var(--border-color,#e5e7eb);flex:1 1;height:2px;max-width:60px}.import-content{flex:1 1;overflow-y:auto;padding:1.5rem}.upload-section{display:flex;flex-direction:column;gap:1.5rem}.upload-area{background:#f9fafb;background:var(--bg-secondary,#f9fafb);border:2px dashed #d1d5db;border:2px dashed var(--border-color,#d1d5db);padding:3rem 2rem}.upload-area:hover{background:#667eea0d;border-color:#667eea}.upload-area svg{color:#667eea;margin-bottom:1rem}.upload-area h3{color:#111827;color:var(--text-primary,#111827);margin:0 0 .5rem}.upload-area p{color:#6b7280;color:var(--text-secondary,#6b7280);font-size:.875rem;margin:0}.upload-actions{display:flex;gap:1rem;justify-content:center}.guide-btn,.template-btn{align-items:center;border-radius:8px;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;padding:.75rem 1.25rem;transition:all .2s}.template-btn{background:#10b981;border:none;color:#fff}.template-btn:hover{background:#059669}.guide-btn{background:#0000;border:1px solid #d1d5db;border:1px solid var(--border-color,#d1d5db);color:#6b7280;color:var(--text-secondary,#6b7280)}.guide-btn:hover{background:#f3f4f6;background:var(--bg-secondary,#f3f4f6)}.format-guide{background:#f9fafb;background:var(--bg-secondary,#f9fafb);border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);border-radius:12px;padding:1.25rem}.format-guide h4{align-items:center;color:#111827;color:var(--text-primary,#111827);display:flex;gap:.5rem;margin:0 0 1rem}.guide-section{margin-bottom:1rem}.guide-section:last-child{margin-bottom:0}.guide-section h5{color:#6b7280;color:var(--text-secondary,#6b7280);font-size:.875rem;margin:0 0 .5rem}.guide-section ul{font-size:.875rem;margin:0;padding-left:1.5rem}.guide-section li{margin-bottom:.25rem}.badge{border-radius:4px;display:inline-block;font-size:.75rem;font-weight:500;padding:.125rem .5rem;text-transform:uppercase}.badge-buy{background:#10b9811a;color:#10b981}.badge-sell{background:#ef44441a;color:#ef4444}.badge-topup{background:#3b82f61a;color:#3b82f6}.badge-withdraw{background:#f973161a;color:#f97316}.badge-dividend{background:#8b5cf61a;color:#8b5cf6}.loading-indicator{align-items:center;color:#6b7280;color:var(--text-secondary,#6b7280);display:flex;flex-direction:column;gap:.75rem;padding:2rem}.loading-indicator .spin{animation:spin 1s linear infinite}.preview-section{display:flex;flex-direction:column;gap:1.25rem}.preview-summary{display:flex;flex-wrap:wrap;gap:1rem}.summary-item{align-items:center;border-radius:8px;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;padding:.75rem 1rem}.summary-item.success{background:#10b9811a;color:#10b981}.summary-item.error{background:#ef44441a;color:#ef4444}.summary-item.warning{background:#f59e0b1a;color:#f59e0b}.errors-list,.warnings-list{background:#f9fafb;background:var(--bg-secondary,#f9fafb);border-radius:8px;max-height:150px;overflow-y:auto;padding:1rem}.errors-list h4,.warnings-list h4{align-items:center;display:flex;font-size:.875rem;gap:.5rem;margin:0 0 .75rem}.errors-list h4{color:#ef4444}.warnings-list h4{color:#f59e0b}.errors-list ul,.warnings-list ul{font-size:.8rem;margin:0;padding-left:1.5rem}.errors-list li,.warnings-list li{margin-bottom:.25rem}.errors-list .more,.warnings-list .more{color:#6b7280;color:var(--text-secondary,#6b7280);font-style:italic}.preview-table-container{background:#f9fafb;background:var(--bg-secondary,#f9fafb);border-radius:8px;padding:1rem}.preview-table-container h4{color:#111827;color:var(--text-primary,#111827);font-size:.875rem;margin:0 0 .75rem}.preview-table-wrapper{max-height:300px;overflow-x:auto}.preview-table{border-collapse:collapse;font-size:.8rem;width:100%}.preview-table td,.preview-table th{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color,#e5e7eb);padding:.5rem .75rem;text-align:left}.preview-table th{background:#fff;background:var(--bg-card,#fff);font-weight:600;position:-webkit-sticky;position:sticky;top:0}.preview-table tbody tr:hover{background:#667eea0d}.table-more{color:#6b7280;color:var(--text-secondary,#6b7280);font-size:.8rem;padding:.75rem;text-align:center}.preview-actions,.table-more{border-top:1px solid #e5e7eb;border-top:1px solid var(--border-color,#e5e7eb)}.preview-actions{display:flex;gap:1rem;justify-content:flex-end;padding-top:1rem}.cancel-btn,.import-btn{align-items:center;border-radius:8px;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;padding:.75rem 1.5rem;transition:all .2s}.cancel-btn{background:#0000;border:1px solid #d1d5db;border:1px solid var(--border-color,#d1d5db);color:#6b7280;color:var(--text-secondary,#6b7280)}.cancel-btn:hover{background:#f3f4f6;background:var(--bg-secondary,#f3f4f6)}.import-btn{background:#667eea;background:var(--primary-color,#667eea);border:none;color:#fff}.import-btn:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.import-btn:disabled{cursor:not-allowed;opacity:.5}.importing-section{align-items:center;display:flex;flex-direction:column;gap:1rem;justify-content:center;padding:3rem}.importing-section svg{color:#667eea}.importing-section h3{color:#111827;color:var(--text-primary,#111827);margin:0}.importing-section p{color:#6b7280;color:var(--text-secondary,#6b7280);font-size:.875rem;margin:0}.complete-section{align-items:center;display:flex;flex-direction:column;gap:1.5rem;padding:2rem}.complete-icon{animation:scaleIn .5s ease-out}.complete-icon.success{color:#10b981}.complete-icon.error{color:#ef4444}.complete-section h3{color:#111827;color:var(--text-primary,#111827);margin:0}.result-stats{display:flex;gap:2rem}.result-stats .stat{align-items:center;display:flex;flex-direction:column;gap:.25rem}.stat-value{font-size:2rem}.stat-label{font-size:.875rem}.stat.success .stat-value{color:#10b981}.stat.error .stat-value{color:#ef4444}.import-errors{background:#ef44441a;border-radius:8px;max-height:150px;overflow-y:auto;padding:1rem;width:100%}.import-errors h4{color:#ef4444;font-size:.875rem;margin:0 0 .5rem}.import-errors ul{color:#b91c1c;font-size:.8rem;margin:0;padding-left:1.5rem}.complete-actions{display:flex;gap:1rem}.primary-btn,.secondary-btn{border-radius:8px;cursor:pointer;font-size:.875rem;font-weight:500;padding:.75rem 1.5rem;transition:all .2s}.secondary-btn{background:#0000;border:1px solid #d1d5db;border:1px solid var(--border-color,#d1d5db);color:#6b7280;color:var(--text-secondary,#6b7280)}.secondary-btn:hover{background:#f3f4f6;background:var(--bg-secondary,#f3f4f6)}.primary-btn{background:#10b981;border:none;color:#fff}.primary-btn:hover{opacity:.9;transform:translateY(-1px)}@media (max-width:640px){.csv-import-modal{border-radius:0;max-height:100vh}.import-steps{padding:1rem .5rem}.step span{display:none}.complete-actions,.preview-actions,.upload-actions{flex-direction:column}.result-stats{gap:1rem}}.portfolio-charts-section{margin-top:2rem;padding:0}.charts-header{align-items:center;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;margin-bottom:1.5rem;padding-bottom:1rem}.charts-title-wrapper{align-items:center;display:flex;gap:1rem}.charts-icon{align-items:center;background:var(--primary-color);border-radius:12px;color:#fff;display:flex;height:48px;justify-content:center;width:48px}.charts-title-wrapper h2{color:var(--text-primary);font-size:1.5rem;font-weight:700;margin:0}.charts-title-wrapper p{color:var(--text-secondary);font-size:.875rem;margin:.25rem 0 0}.charts-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(2,1fr)}.chart-card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:16px;box-shadow:0 2px 8px var(--card-shadow);padding:1.5rem;transition:box-shadow .3s ease,transform .3s ease}.chart-card:hover{box-shadow:0 4px 16px var(--card-shadow-hover)}.chart-card-wide{grid-column:span 2}.chart-card-header{align-items:center;border-bottom:1px solid var(--border-color-light);display:flex;gap:.75rem;margin-bottom:1rem;padding-bottom:.75rem}.chart-card-header svg{color:var(--primary-color)}.chart-card-header h3{color:var(--text-primary);font-size:1rem;font-weight:600;margin:0}.chart-container{width:100%}.chart-container,.donut-chart{position:relative}.donut-center{left:50%;pointer-events:none;position:absolute;text-align:center;top:50%;transform:translate(-50%,-60%)}.donut-label{color:var(--text-secondary);display:block;font-size:.75rem;margin-bottom:.25rem}.donut-value{color:var(--text-primary);display:block;font-size:1.75rem;font-weight:700}.chart-legend-container{border-top:1px solid var(--border-color-light);display:flex;flex-wrap:wrap;gap:.75rem;margin-top:1rem;padding-top:1rem}.legend-item{background:var(--bg-secondary);border-radius:20px;font-size:.8rem;gap:.5rem;padding:.375rem .75rem}.legend-color{border-radius:50%;height:10px;width:10px}.legend-text{color:var(--text-primary);font-weight:500}.legend-percent{color:var(--text-secondary);font-size:.75rem}.legend-more{background:var(--bg-tertiary);color:var(--text-tertiary)}.portfolio-chart-tooltip{background:var(--card-bg);border:1px solid var(--border-color);border-radius:10px;box-shadow:0 4px 16px var(--card-shadow-lg);min-width:160px;padding:.875rem}.portfolio-chart-tooltip .tooltip-label{border-bottom:1px solid var(--border-color-light);color:var(--text-primary);font-size:.875rem;font-weight:600;margin-bottom:.5rem;padding-bottom:.5rem}.portfolio-chart-tooltip .tooltip-item{align-items:center;display:flex;font-size:.8rem;gap:.5rem;margin:.375rem 0}.portfolio-chart-tooltip .tooltip-color{border-radius:50%;flex-shrink:0;height:8px;width:8px}.portfolio-chart-tooltip .tooltip-name{color:var(--text-secondary)}.portfolio-chart-tooltip .tooltip-value{color:var(--text-primary);font-weight:600;margin-left:auto}.stats-card{grid-column:span 1}.stats-grid{grid-template-columns:repeat(2,1fr)}.stat-item{background:var(--bg-secondary);border:1px solid var(--border-color-light);border-radius:12px;gap:.375rem;transition:background .2s ease}.stat-item:hover{background:var(--bg-tertiary)}.stat-label{color:var(--text-secondary);letter-spacing:.5px}.stat-value{color:var(--text-primary);font-size:1.125rem}.stat-value.positive{color:var(--success-color)}.stat-value.negative{color:var(--error-color)}.stat-value.highlight{color:var(--primary-color)}.stat-value.danger{color:var(--error-color)}.portfolio-charts-empty{align-items:center;background:var(--card-bg);border:2px dashed var(--border-color);border-radius:16px;color:var(--text-secondary);display:flex;flex-direction:column;justify-content:center;margin-top:2rem;padding:4rem 2rem;text-align:center}.portfolio-charts-empty svg{margin-bottom:1rem;opacity:.5}.portfolio-charts-empty p{font-size:1rem;margin:0}.recharts-legend-item-text{color:var(--text-primary)!important;font-size:.8rem!important}.recharts-legend-wrapper{padding-top:1rem!important}.recharts-default-legend{display:flex;gap:1.5rem;justify-content:center}.recharts-tooltip-wrapper{z-index:100}@media (max-width:1200px){.charts-grid{grid-template-columns:1fr}.chart-card-wide{grid-column:span 1}}@media (max-width:768px){.portfolio-charts-section{margin-top:1.5rem}.charts-header{align-items:flex-start;flex-direction:column;gap:1rem}.charts-icon{height:40px;width:40px}.charts-title-wrapper h2{font-size:1.25rem}.chart-card{border-radius:12px;padding:1rem}.chart-card-header h3{font-size:.9rem}.donut-center{transform:translate(-50%,-50%)}.donut-value{font-size:1.5rem}.stats-grid{grid-template-columns:1fr}.stat-item{padding:.75rem}.stat-value{font-size:1rem}.chart-legend-container{gap:.5rem}.legend-item{font-size:.7rem;padding:.25rem .5rem}}@media (max-width:480px){.charts-title-wrapper{gap:.75rem}.charts-icon{height:36px;width:36px}.charts-icon svg{height:18px;width:18px}.charts-title-wrapper h2{font-size:1.1rem}.charts-title-wrapper p{font-size:.75rem}.chart-card{padding:.875rem}.portfolio-charts-empty{padding:2rem 1rem}}.analytics-container{background:#f8fafc;background:var(--bg-primary,#f8fafc);color:#1e293b;color:var(--text-primary,#1e293b);min-height:100vh;padding:0 2rem 2rem;width:100%}.analytics-loading{color:#64748b;color:var(--text-secondary,#64748b);flex-direction:column;gap:1rem;min-height:60vh}.analytics-loading,.loading-spinner{align-items:center;display:flex;justify-content:center}.loading-spinner{background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:50%;color:#fff;height:64px;width:64px}.loading-spinner .spin{animation:spin 1s linear infinite}.loading-subtitle{font-size:.875rem;opacity:.7}.analytics-error{align-items:center;color:var(--text-secondary);display:flex;flex-direction:column;gap:1rem;justify-content:center;min-height:60vh;text-align:center}.analytics-error svg{color:#ef4444;opacity:.8}.analytics-error h3{color:var(--text-primary);font-size:1.25rem;font-weight:600;margin:0}.analytics-error p{color:var(--text-secondary);margin:0}.retry-btn{align-items:center;background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;border-radius:10px;color:#fff;cursor:pointer;display:flex;font-weight:500;gap:.5rem;padding:.75rem 1.5rem;transition:all .2s ease}.retry-btn:hover{box-shadow:0 4px 12px #6366f14d;transform:translateY(-2px)}.analytics-header-section{align-items:center;background:#fff;background:var(--card-bg,#fff);border:1px solid #e2e8f0;border:1px solid var(--border-color,#e2e8f0);border-radius:16px;box-shadow:0 4px 20px #0000000d;box-shadow:0 4px 20px var(--card-shadow,#0000000d);display:flex;gap:1.5rem;margin-bottom:1.5rem;overflow:hidden;padding:1.25rem 2rem;position:relative}.analytics-header-section:before{background:linear-gradient(135deg,#6366f1,#8b5cf6);content:"";height:4px;left:0;position:absolute;right:0;top:0}.analytics-header-section .header-icon-wrapper{flex-shrink:0}.analytics-header-section .header-icon{align-items:center;background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:12px;box-shadow:0 4px 12px #6366f14d;color:#fff;display:flex;height:48px;justify-content:center;width:48px}.analytics-header-section .header-content{flex:1 1}.analytics-header-section .header-title{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,var(--text-primary) 0,#6366f1 100%);-webkit-background-clip:text;background-clip:text;color:var(--text-primary);font-size:1.5rem;font-weight:700;margin:0 0 .25rem}.analytics-header-section .header-subtitle{color:var(--text-secondary);font-size:.875rem;margin:0}.refresh-btn{background:#fff;background:var(--card-bg,#fff);border:1px solid #e2e8f0;border:1px solid var(--border-color,#e2e8f0);color:var(--text-secondary);font-size:.875rem;font-weight:500;gap:.5rem;padding:.6rem 1rem}.refresh-btn:hover{background:#f1f5f9;background:var(--bg-hover,#f1f5f9);border-color:#6366f1;color:#6366f1}.analytics-tabs{background:#fff;background:var(--card-bg,#fff);border:1px solid #e2e8f0;border:1px solid var(--border-color,#e2e8f0);border-radius:12px;display:flex;gap:.5rem;padding:.25rem}.tab-btn{border-radius:8px}.tab-btn:hover{background:#f1f5f9;background:var(--bg-hover,#f1f5f9)}.tab-btn.active{background:linear-gradient(135deg,#6366f1,#8b5cf6)}.quick-stats{grid-gap:1rem;background:#fff;background:var(--card-bg,#fff);border:1px solid #e2e8f0;border:1px solid var(--border-color,#e2e8f0);border-radius:16px;display:grid;gap:1rem;grid-template-columns:repeat(4,1fr);margin-bottom:1.5rem;padding:1.25rem}.quick-stat{border-right:1px solid #e2e8f0;border-right:1px solid var(--border-color,#e2e8f0);display:flex;flex-direction:column;gap:.25rem;padding:0 1rem}.quick-stat:last-child{border-right:none}.quick-stat .stat-label{color:var(--text-secondary);font-size:.75rem;font-weight:500;letter-spacing:.05em;text-transform:uppercase}.quick-stat .stat-value{color:var(--text-primary);font-size:1.25rem;font-weight:700}.quick-stat .stat-value.positive{color:#10b981}.quick-stat .stat-value.negative{color:#ef4444}.quick-stat .stat-value.risk-low{color:#10b981}.quick-stat .stat-value.risk-medium{color:#f59e0b}.quick-stat .stat-value.risk-high{color:#ef4444}.metrics-grid{grid-gap:1.25rem;display:grid;gap:1.25rem;grid-template-columns:repeat(3,1fr);margin-bottom:1.5rem}.metrics-grid .metric-card:first-child,.metrics-grid .metric-card:nth-child(2){grid-column:span 1}@media (min-width:1400px){.metrics-grid{grid-template-columns:repeat(6,1fr)}.metrics-grid .metric-card:first-child,.metrics-grid .metric-card:nth-child(2),.metrics-grid .metric-card:nth-child(n+3){grid-column:span 2}}.metric-card{background:#fff;background:var(--card-bg,#fff);border:1px solid #e2e8f0;border:1px solid var(--border-color,#e2e8f0);border-radius:16px;overflow:hidden;padding:1.5rem;position:relative;transition:all .2s ease}.metric-card:hover{box-shadow:0 8px 25px #00000014;transform:translateY(-2px)}.metric-card.primary{grid-column:span 1}.card-header{align-items:flex-start;margin-bottom:1rem}.card-icon{align-items:center;border-radius:12px;color:#fff;display:flex;height:48px;justify-content:center;width:48px}.xirr-card .card-icon{background:linear-gradient(135deg,#6366f1,#8b5cf6)}.return-card .card-icon{background:linear-gradient(135deg,#10b981,#059669)}.winrate-card .card-icon{background:linear-gradient(135deg,#ec4899,#d946ef)}.profit-factor-card .card-icon{background:linear-gradient(135deg,#3b82f6,#2563eb)}.holding-card .card-icon{background:linear-gradient(135deg,#f59e0b,#d97706)}.drawdown-card .card-icon{background:linear-gradient(135deg,#ef4444,#dc2626)}.card-badge{background:#6366f11a;border-radius:20px;color:#6366f1;font-size:.7rem;font-weight:600;letter-spacing:.05em;padding:.25rem .75rem;text-transform:uppercase}.card-badge.warning{background:#ef44441a;color:#ef4444}.card-body{display:flex;flex-direction:column;gap:.5rem}.metric-label{color:var(--text-secondary);font-size:.875rem;font-weight:500;margin:0}.metric-value{color:var(--text-primary);font-size:2rem;font-weight:700;line-height:1.2}.metric-value.positive{color:#10b981}.metric-value.negative{color:#ef4444}.metric-value.neutral{color:var(--text-primary)}.metric-description{color:var(--text-secondary);font-size:.8rem;margin:0}.card-progress{background:#f1f5f9;background:var(--bg-secondary,#f1f5f9);border-radius:2px;height:4px;margin-top:1rem;overflow:hidden}.progress-bar{background:linear-gradient(90deg,#ec4899,#d946ef);border-radius:2px;height:100%;transition:width .5s ease}.stats-sections{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(2,1fr)}.stats-section{background:#fff;background:var(--card-bg,#fff);border:1px solid #e2e8f0;border:1px solid var(--border-color,#e2e8f0);border-radius:16px;padding:1.5rem}.section-header{border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border-color,#e2e8f0);gap:.75rem;margin-bottom:1.25rem}.section-header svg{color:#6366f1}.section-header h3{color:var(--text-primary);font-size:1rem;font-weight:600;margin:0}.stats-grid{grid-gap:1rem;gap:1rem;grid-template-columns:repeat(3,1fr)}.stat-item{display:flex;flex-direction:column;gap:.25rem}.stat-item .stat-label{color:var(--text-secondary);font-size:.75rem;font-weight:500}.stat-item .stat-value{color:var(--text-primary);font-size:1rem;font-weight:600}.stat-item .stat-value.positive{color:#10b981}.stat-item .stat-value.negative{color:#ef4444}.stat-item .stat-value.date{font-size:.875rem}[data-theme=dark] .analytics-container{background:#0f172a;background:var(--bg-primary,#0f172a);color:#f1f5f9;color:var(--text-primary,#f1f5f9)}[data-theme=dark] .analytics-error,[data-theme=dark] .analytics-loading{color:#94a3b8;color:var(--text-secondary,#94a3b8)}[data-theme=dark] .analytics-error h3,[data-theme=dark] .header-title h1,[data-theme=dark] .section-header h3{color:#f1f5f9;color:var(--text-primary,#f1f5f9)}[data-theme=dark] .analytics-error p,[data-theme=dark] .header-subtitle,[data-theme=dark] .loading-subtitle{color:#94a3b8;color:var(--text-secondary,#94a3b8)}[data-theme=dark] .analytics-tabs,[data-theme=dark] .metric-card,[data-theme=dark] .quick-stats,[data-theme=dark] .refresh-btn,[data-theme=dark] .stats-section{background:#1e293b;background:var(--card-bg,#1e293b);border-color:#334155;border-color:var(--border-color,#334155)}[data-theme=dark] .tab-btn{color:#94a3b8;color:var(--text-secondary,#94a3b8)}[data-theme=dark] .tab-btn:hover{background:#334155;background:var(--bg-hover,#334155);color:#f1f5f9;color:var(--text-primary,#f1f5f9)}[data-theme=dark] .quick-stat{border-color:#334155;border-color:var(--border-color,#334155)}[data-theme=dark] .metric-value,[data-theme=dark] .metric-value.neutral,[data-theme=dark] .quick-stat .stat-value,[data-theme=dark] .stat-item .stat-value{color:#f1f5f9;color:var(--text-primary,#f1f5f9)}[data-theme=dark] .metric-description,[data-theme=dark] .metric-label,[data-theme=dark] .quick-stat .stat-label,[data-theme=dark] .stat-item .stat-label{color:#94a3b8;color:var(--text-secondary,#94a3b8)}[data-theme=dark] .section-header{border-color:#334155;border-color:var(--border-color,#334155)}[data-theme=dark] .card-progress{background:#334155;background:var(--bg-secondary,#334155)}[data-theme=dark] .card-badge{background:#818cf826;color:#818cf8}[data-theme=dark] .card-badge.warning{background:#f8717126;color:#f87171}@media (max-width:1200px){.metrics-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:992px){.quick-stats{grid-template-columns:repeat(2,1fr)}.quick-stat:nth-child(2){border-right:none}.quick-stat:nth-child(3),.quick-stat:nth-child(4){border-top:1px solid #e2e8f0;border-top:1px solid var(--border-color,#e2e8f0);padding-top:1rem}.stats-sections{grid-template-columns:1fr}}@media (max-width:768px){.analytics-container{padding:0 1rem 1.5rem}.header-content{flex-direction:column;gap:1rem}.refresh-btn{justify-content:center;width:100%}.analytics-tabs{-webkit-overflow-scrolling:touch;overflow-x:auto}.tab-btn{flex-shrink:0;white-space:nowrap}.metrics-grid,.quick-stats{grid-template-columns:1fr}.quick-stat{border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border-color,#e2e8f0);border-right:none;padding-bottom:1rem}.quick-stat:last-child{border-bottom:none;padding-bottom:0}.stats-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:480px){.header-title h1,.metric-value{font-size:1.5rem}.stats-grid{grid-template-columns:1fr}}.investment-goals{padding:1rem}.goals-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.5rem}.goals-header h2{color:#1f2937;color:var(--text-primary,#1f2937);font-size:1.5rem;font-weight:600;margin:0}.add-goal-btn,.goals-header h2{align-items:center;display:flex;gap:.5rem}.add-goal-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:500;padding:.6rem 1.2rem;transition:all .2s ease}.add-goal-btn:hover{box-shadow:0 4px 12px #667eea66;transform:translateY(-1px)}.goals-summary{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(4,1fr);margin-bottom:2rem}.summary-card{gap:.25rem}.summary-card .summary-label{color:#6b7280;color:var(--text-secondary,#6b7280);font-size:.75rem;letter-spacing:.05em;text-transform:uppercase}.summary-card .summary-value{color:#1f2937;color:var(--text-primary,#1f2937);font-size:1.25rem;font-weight:700}.summary-card .summary-value.success{color:#10b981}.goals-list{display:flex;flex-direction:column;gap:1rem}.goal-card{background:#fff;background:var(--bg-card,#fff);border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);border-radius:12px;display:flex;gap:1rem;padding:1.25rem;transition:all .2s ease}.goal-card:hover{box-shadow:0 4px 12px #00000014}.goal-card.completed{background:linear-gradient(135deg,#d1fae5,#ecfdf5);border-color:#10b981}.goal-icon{align-items:center;border-radius:12px;color:#fff;display:flex;flex-shrink:0;font-size:1.5rem;height:48px;justify-content:center;width:48px}.goal-content{flex:1 1;min-width:0}.goal-content .goal-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.75rem}.goal-content .goal-header h3{color:#1f2937;color:var(--text-primary,#1f2937);font-size:1.1rem;font-weight:600;margin:0}.goal-actions{display:flex;gap:.5rem}.goal-actions button{background:#0000;border:none;border-radius:6px;color:#6b7280;color:var(--text-secondary,#6b7280);cursor:pointer;padding:.35rem;transition:all .2s ease}.goal-actions button:hover{background:#f3f4f6;background:var(--bg-secondary,#f3f4f6);color:#1f2937;color:var(--text-primary,#1f2937)}.goal-actions button:last-child:hover{color:#ef4444}.goal-progress{margin-bottom:.75rem}.progress-bar{background:#e5e7eb;background:var(--bg-secondary,#e5e7eb);border-radius:4px;height:8px;margin-bottom:.5rem;overflow:hidden}.progress-fill{border-radius:4px;height:100%;transition:width .5s ease}.progress-info{color:#6b7280;color:var(--text-secondary,#6b7280);display:flex;font-size:.8rem;justify-content:space-between}.progress-percent{color:#1f2937;color:var(--text-primary,#1f2937);font-weight:600}.goal-meta{display:flex;flex-wrap:wrap;font-size:.8rem;gap:1rem}.goal-meta span{align-items:center;color:#6b7280;color:var(--text-secondary,#6b7280);display:flex;gap:.35rem}.goal-deadline.overdue{color:#ef4444}.goal-status.on-track{color:#10b981}.goal-status.behind{color:#f59e0b}.projected-date{color:#3b82f6}.no-goals{background:#fff;background:var(--bg-card,#fff);border:2px dashed #e5e7eb;border:2px dashed var(--border-color,#e5e7eb);border-radius:12px;padding:4rem 2rem;text-align:center}.no-goals svg{color:#9ca3af;color:var(--text-muted,#9ca3af);margin-bottom:1rem}.no-goals h3{color:#1f2937;color:var(--text-primary,#1f2937);margin:0 0 .5rem}.no-goals p{color:#6b7280;color:var(--text-secondary,#6b7280);margin-bottom:1.5rem}.no-goals button{align-items:center;background:#3b82f6;background:var(--primary-color,#3b82f6);border:none;border-radius:8px;color:#fff;cursor:pointer;display:inline-flex;font-weight:500;gap:.5rem;padding:.6rem 1.2rem}.goal-modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000}.goal-modal{background:#fff;background:var(--bg-card,#fff);border-radius:16px;max-height:90vh;max-width:500px;overflow-y:auto;width:100%}.goal-modal form{padding:1.25rem}.icon-selector{display:flex;flex-wrap:wrap;gap:.5rem}.icon-selector button{background:#f3f4f6;background:var(--bg-secondary,#f3f4f6);border:2px solid #e5e7eb;border:2px solid var(--border-color,#e5e7eb);border-radius:10px;cursor:pointer;font-size:1.25rem;height:40px;transition:all .2s ease;width:40px}.icon-selector button.selected{background:#3b82f61a;border-color:#3b82f6;border-color:var(--primary-color,#3b82f6)}.icon-selector button:hover{transform:scale(1.1)}.goals-loading{align-items:center;color:#6b7280;color:var(--text-secondary,#6b7280);display:flex;flex-direction:column;gap:1rem;justify-content:center;padding:3rem}.goals-loading .spin{animation:spin 1s linear infinite}@media (max-width:768px){.goals-summary{grid-template-columns:repeat(2,1fr)}.form-row{grid-template-columns:1fr}.goal-card{flex-direction:column}.goal-icon{font-size:1.25rem;height:40px;width:40px}}@media (max-width:480px){.goals-summary{grid-template-columns:1fr}.goal-meta{flex-direction:column;gap:.5rem}}.sector-allocation{padding:1rem}.allocation-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.5rem}.allocation-header h2{align-items:center;color:#1f2937;color:var(--text-primary,#1f2937);display:flex;font-size:1.5rem;font-weight:600;gap:.5rem;margin:0}.refresh-btn{background:#f3f4f6;background:var(--bg-secondary,#f3f4f6);border:none;border-radius:8px;padding:.5rem;transition:all .2s ease}.refresh-btn:hover{background:#e5e7eb;background:var(--bg-tertiary,#e5e7eb)}.allocation-content{grid-gap:1.5rem;display:grid;gap:1.5rem}.diversification-card{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;color:#fff;display:flex;gap:1.5rem;padding:1.5rem}.score-circle{align-items:center;background:#ffffff26;border:4px solid #fff;border-radius:50%;display:flex;flex-direction:column;flex-shrink:0;height:100px;justify-content:center;width:100px}.score-value{font-size:2rem;font-weight:700;line-height:1}.score-grade{margin-top:.25rem}.score-grade,.score-info h3{font-size:1.25rem;font-weight:600}.score-info h3{margin:0 0 .5rem}.score-info p{font-size:.9rem;line-height:1.4;margin:0 0 1rem;opacity:.9}.score-meta{display:flex;font-size:.85rem;gap:1.5rem;opacity:.9}.chart-container{display:flex;justify-content:center;padding:1rem}.pie-chart{height:250px;position:relative;width:250px}.pie-chart svg{height:100%;transform:rotate(-90deg);width:100%}.chart-center{left:50%;position:absolute;text-align:center;top:50%;transform:translate(-50%,-50%)}.center-value{color:#1f2937;color:var(--text-primary,#1f2937);display:block;font-size:2rem;font-weight:700}.center-label{color:#6b7280;color:var(--text-secondary,#6b7280);display:block;font-size:.85rem}.sector-legend{background:#fff;background:var(--bg-card,#fff);border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);border-radius:12px;padding:1rem}.legend-item{align-items:center;border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color,#e5e7eb);display:flex;gap:.75rem;padding:.75rem 0}.legend-item:last-child{border-bottom:none}.legend-color{border-radius:4px;flex-shrink:0;height:16px;width:16px}.legend-info{display:flex;flex:1 1;flex-direction:column;gap:.15rem}.legend-name{color:#1f2937;color:var(--text-primary,#1f2937);font-size:.95rem;font-weight:600}.legend-value{color:#6b7280;color:var(--text-secondary,#6b7280);font-size:.8rem}.legend-positions{color:#9ca3af;color:var(--text-muted,#9ca3af);font-size:.75rem;white-space:nowrap}.no-data{gap:.5rem}.concentration-risks{background:#fef3c7;border:1px solid #fcd34d;border-radius:12px;padding:1rem}.concentration-risks h3{font-size:1rem;font-weight:600;margin:0 0 .75rem}.concentration-risks h3,.risk-item{align-items:center;color:#92400e;display:flex;gap:.5rem}.risk-item{font-size:.9rem;padding:.5rem 0}.suggestions{background:#fff;background:var(--bg-card,#fff);border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);border-radius:12px;padding:1rem}.suggestions h3{color:#1f2937;color:var(--text-primary,#1f2937);font-size:1rem;font-weight:600;margin:0 0 .75rem}.suggestion-item,.suggestions h3{align-items:center;display:flex;gap:.5rem}.suggestion-item{font-size:.9rem;padding:.5rem 0}.suggestion-item.reduce{color:#f59e0b}.suggestion-item.add{color:#10b981}.allocation-loading{align-items:center;color:#6b7280;color:var(--text-secondary,#6b7280);display:flex;flex-direction:column;gap:1rem;justify-content:center;padding:3rem}.allocation-loading .spin{animation:spin 1s linear infinite}@media (max-width:768px){.diversification-card{flex-direction:column;text-align:center}.score-meta{justify-content:center}.pie-chart{height:200px;width:200px}}.tax-report{margin:0 auto;max-width:800px;padding:1rem}.tax-header{flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:1.5rem}.tax-header,.tax-header h2{align-items:center;display:flex}.tax-header h2{color:#1f2937;color:var(--text-primary,#1f2937);font-size:1.5rem;font-weight:600;gap:.5rem;margin:0}.header-actions{align-items:center;display:flex;gap:.75rem}.year-selector{background:#fff;background:var(--bg-card,#fff);border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);border-radius:8px;cursor:pointer;font-size:.95rem;padding:.5rem 1rem}.export-btn{background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:8px;color:#fff}.export-btn:hover:not(:disabled){box-shadow:0 4px 12px #10b98166;transform:translateY(-1px)}.export-btn:disabled{cursor:not-allowed;opacity:.6}.tax-disclaimer{align-items:flex-start;background:#fef3c7;border:1px solid #fcd34d;border-radius:10px;display:flex;gap:.75rem;margin-bottom:1.5rem;padding:1rem}.tax-disclaimer svg{color:#92400e;flex-shrink:0;margin-top:2px}.tax-disclaimer p{color:#92400e;font-size:.9rem;line-height:1.4;margin:0}.tax-summary-cards{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(4,1fr);margin-bottom:1.5rem}.summary-card.highlight{background:linear-gradient(135deg,#667eea,#764ba2);border:none;color:#fff}.summary-card.highlight .card-label{color:#fffc}.summary-card.highlight .card-value{color:#fff}.tax-section{background:#fff;background:var(--bg-card,#fff);border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);border-radius:12px;margin-bottom:1rem;overflow:hidden}.section-header{cursor:pointer;padding:1rem 1.25rem;transition:background .2s ease}.section-header:hover{background:#f9fafb;background:var(--bg-secondary,#f9fafb)}.section-title{align-items:center;display:flex;gap:.5rem}.section-title h3{color:#1f2937;color:var(--text-primary,#1f2937);font-size:1rem;font-weight:600;margin:0}.section-content{border-top:1px solid #e5e7eb;border-top:1px solid var(--border-color,#e5e7eb);padding:0 1.25rem 1.25rem}.tax-item{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color,#e5e7eb);padding:1rem 0}.tax-item:last-child{border-bottom:none}.tax-item-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.75rem}.tax-name{color:#1f2937;color:var(--text-primary,#1f2937);font-weight:600}.tax-rate{background:#f3f4f6;background:var(--bg-secondary,#f3f4f6);border-radius:20px;font-size:.85rem;font-weight:500;padding:.25rem .75rem}.tax-item-details .detail-row{display:flex;font-size:.9rem;justify-content:space-between;padding:.35rem 0}.tax-amount{color:#1f2937;color:var(--text-primary,#1f2937);font-weight:600}.tax-note{align-items:center;background:#f9fafb;background:var(--bg-secondary,#f9fafb);border-radius:8px;color:#6b7280;color:var(--text-secondary,#6b7280);display:flex;font-size:.8rem;gap:.5rem;margin:.75rem 0 0;padding:.75rem}.transaction-stats{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(4,1fr);padding-top:1rem}.stat-item{background:#f9fafb;background:var(--bg-secondary,#f9fafb);border-radius:10px;padding:1rem;text-align:center}.stat-value{color:#1f2937;color:var(--text-primary,#1f2937);display:block;font-size:1.5rem;font-weight:700}.stat-value.positive{color:#10b981}.stat-value.negative{color:#ef4444}.stat-label{color:#6b7280;color:var(--text-secondary,#6b7280);display:block;font-size:.75rem;letter-spacing:.05em;margin-top:.25rem;text-transform:uppercase}.monthly-table{padding-top:1rem}.table-header,.table-row{grid-gap:.5rem;display:grid;gap:.5rem;grid-template-columns:2fr repeat(4,1fr);padding:.75rem 0}.table-header{border-bottom:2px solid #e5e7eb;border-bottom:2px solid var(--border-color,#e5e7eb);color:#6b7280;color:var(--text-secondary,#6b7280);font-size:.75rem;letter-spacing:.05em;text-transform:uppercase}.table-row{border-bottom:1px solid #f3f4f6;border-bottom:1px solid var(--border-color,#f3f4f6);font-size:.9rem}.table-row:last-child{border-bottom:none}.no-data{color:#6b7280;color:var(--text-secondary,#6b7280);padding:2rem;text-align:center}.spt-notes{background:linear-gradient(135deg,#dbeafe,#ede9fe);border-radius:12px;margin-top:1.5rem;padding:1.25rem}.spt-notes h3{color:#1e40af;font-size:1rem;font-weight:600;margin:0 0 .75rem}.spt-notes ul{margin:0;padding-left:1.25rem}.spt-notes li{color:#3730a3;font-size:.9rem;line-height:1.4;margin-bottom:.5rem}.spt-notes li:last-child{margin-bottom:0}.tax-loading{align-items:center;color:#6b7280;color:var(--text-secondary,#6b7280);display:flex;flex-direction:column;gap:1rem;justify-content:center;padding:3rem}.tax-loading .spin{animation:spin 1s linear infinite}@media (max-width:768px){.tax-summary-cards,.transaction-stats{grid-template-columns:repeat(2,1fr)}.table-header,.table-row{grid-template-columns:1.5fr repeat(2,1fr)}.table-header span:nth-child(4),.table-header span:nth-child(5),.table-row span:nth-child(4),.table-row span:nth-child(5){display:none}}@media (max-width:480px){.header-actions{justify-content:space-between;width:100%}.tax-summary-cards,.transaction-stats{grid-template-columns:1fr}}.dca-tracker{padding:1rem}.dca-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.5rem}.dca-header h2{color:#1f2937;color:var(--text-primary,#1f2937);font-size:1.5rem;font-weight:600;margin:0}.add-plan-btn,.dca-header h2{align-items:center;display:flex;gap:.5rem}.add-plan-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:500;padding:.6rem 1.2rem;transition:all .2s ease}.add-plan-btn:hover{box-shadow:0 4px 12px #667eea66;transform:translateY(-1px)}.dca-reminders{background:linear-gradient(135deg,#fef3c7,#fde68a);border:1px solid #fcd34d;border-radius:12px;display:flex;gap:.75rem;margin-bottom:1.5rem;padding:1rem}.dca-reminders svg{color:#92400e;flex-shrink:0;margin-top:2px}.reminder-content{display:flex;flex-direction:column;gap:.25rem}.reminder-content strong{color:#92400e;font-size:.95rem}.reminder-content span{color:#78350f;font-size:.85rem}.dca-summary{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(4,1fr);margin-bottom:1.5rem}.summary-card{background:#fff;background:var(--bg-card,#fff);border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);border-radius:10px;display:flex;flex-direction:column;gap:.35rem;padding:1rem 1.25rem}.summary-card .card-label{color:#6b7280;color:var(--text-secondary,#6b7280);font-size:.75rem;letter-spacing:.05em;text-transform:uppercase}.summary-card .card-value{color:#1f2937;color:var(--text-primary,#1f2937);font-size:1.1rem;font-weight:700}.summary-card .card-value.positive{color:#10b981}.summary-card .card-value.negative{color:#ef4444}.plans-list{grid-gap:1rem;display:grid;gap:1rem}.plan-card{background:#fff;background:var(--bg-card,#fff);border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);padding:1.25rem;transition:all .2s ease}.plan-card:hover{box-shadow:0 4px 12px #00000014}.plan-card.paused{border-color:#f59e0b;opacity:.7}.plan-card.completed{background:linear-gradient(135deg,#d1fae5,#ecfdf5);border-color:#10b981}.plan-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:1rem}.plan-info h3{color:#1f2937;color:var(--text-primary,#1f2937);font-size:1.1rem;font-weight:600;margin:0 0 .25rem}.plan-ticker{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:4px;color:#fff;display:inline-block;font-size:.75rem;font-weight:600;padding:.2rem .6rem}.plan-actions{display:flex;gap:.5rem}.plan-actions button{background:#0000;border:none;border-radius:6px;color:#6b7280;color:var(--text-secondary,#6b7280);cursor:pointer;padding:.35rem;transition:all .2s ease}.plan-actions button:hover{background:#f3f4f6;background:var(--bg-secondary,#f3f4f6);color:#1f2937;color:var(--text-primary,#1f2937)}.plan-actions button.status-btn.pause:hover{color:#f59e0b}.plan-actions button.status-btn.resume:hover{color:#10b981}.plan-actions button:last-child:hover{color:#ef4444}.plan-details{grid-gap:1rem;border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color,#e5e7eb);border-top:1px solid #e5e7eb;border-top:1px solid var(--border-color,#e5e7eb);display:grid;gap:1rem;grid-template-columns:repeat(4,1fr);padding:1rem 0}.detail-item{display:flex;flex-direction:column;gap:.2rem}.detail-label{color:#6b7280;color:var(--text-secondary,#6b7280);font-size:.7rem;letter-spacing:.05em}.detail-value{color:#1f2937;color:var(--text-primary,#1f2937);font-size:.95rem}.plan-performance{display:flex;gap:2rem;padding:1rem 0}.perf-item{display:flex;flex-direction:column;gap:.15rem}.perf-label{color:#6b7280;color:var(--text-secondary,#6b7280);font-size:.7rem}.perf-value{color:#1f2937;color:var(--text-primary,#1f2937);font-size:.9rem;font-weight:600}.perf-value.positive{color:#10b981}.perf-value.negative{color:#ef4444}.next-investment{align-items:center;background:#f3f4f6;background:var(--bg-secondary,#f3f4f6);border-radius:8px;color:#6b7280;color:var(--text-secondary,#6b7280);display:flex;font-size:.85rem;gap:.5rem;margin-top:.5rem;padding:.5rem .75rem}.plan-status-badge{border-radius:12px;font-size:.7rem;font-weight:600;padding:.2rem .6rem;position:absolute;right:1rem;text-transform:uppercase;top:1rem}.plan-status-badge.active{background:#d1fae5;color:#065f46}.plan-status-badge.paused{background:#fef3c7;color:#92400e}.plan-status-badge.completed{background:#dbeafe;color:#1e40af}.no-plans{background:#fff;background:var(--bg-card,#fff);border:2px dashed #e5e7eb;border:2px dashed var(--border-color,#e5e7eb);border-radius:12px;padding:4rem 2rem;text-align:center}.no-plans svg{color:#9ca3af;color:var(--text-muted,#9ca3af);margin-bottom:1rem}.no-plans h3{color:#1f2937;color:var(--text-primary,#1f2937);margin:0 0 .5rem}.no-plans p{color:#6b7280;color:var(--text-secondary,#6b7280);margin-bottom:1.5rem}.no-plans button{align-items:center;background:#3b82f6;background:var(--primary-color,#3b82f6);border:none;border-radius:8px;color:#fff;cursor:pointer;display:inline-flex;font-weight:500;gap:.5rem;padding:.6rem 1.2rem}.dca-modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000}.dca-modal{background:#fff;background:var(--bg-card,#fff);border-radius:16px;max-height:90vh;max-width:500px;overflow-y:auto;width:100%}.close-btn{background:#0000;border:none;border-radius:6px;color:#6b7280;color:var(--text-secondary,#6b7280);cursor:pointer;padding:.35rem}.close-btn:hover{background:#f3f4f6;background:var(--bg-secondary,#f3f4f6)}.dca-modal form{padding:1.25rem}.form-group input,.form-group select,.form-group textarea{background:#fff;background:var(--bg-primary,#fff);border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);border-radius:8px;color:#1f2937;color:var(--text-primary,#1f2937);font-size:.95rem;padding:.6rem .85rem;transition:all .2s ease;width:100%}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#3b82f6;border-color:var(--primary-color,#3b82f6);box-shadow:0 0 0 3px #3b82f61a}.modal-actions{margin-top:1.5rem}.cancel-btn{background:#f3f4f6;background:var(--bg-secondary,#f3f4f6);border:none;border-radius:8px;color:#1f2937;color:var(--text-primary,#1f2937);cursor:pointer}.cancel-btn,.save-btn{font-weight:500;padding:.6rem 1.2rem}.save-btn{background:#3b82f6;background:var(--primary-color,#3b82f6)}.save-btn:hover{opacity:.9}.dca-loading{align-items:center;color:#6b7280;color:var(--text-secondary,#6b7280);display:flex;flex-direction:column;gap:1rem;justify-content:center;padding:3rem}.dca-loading .spin{animation:spin 1s linear infinite}@media (max-width:768px){.dca-summary,.plan-details{grid-template-columns:repeat(2,1fr)}.plan-performance{flex-wrap:wrap;gap:1rem}.form-row{grid-template-columns:1fr}}@media (max-width:480px){.dca-summary{grid-template-columns:1fr}}.watchlist-container{padding:1rem}.watchlist-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.5rem}.watchlist-header h2{color:#1f2937;color:var(--text-primary,#1f2937);font-size:1.5rem;font-weight:600;margin:0}.add-btn,.watchlist-header h2{align-items:center;display:flex;gap:.5rem}.add-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:500;padding:.6rem 1.2rem;transition:all .2s ease}.add-btn:hover{box-shadow:0 4px 12px #667eea66;transform:translateY(-1px)}.alerts-banner{background:linear-gradient(135deg,#fef3c7,#fde68a);border:1px solid #fcd34d;border-radius:12px;display:flex;gap:1rem;margin-bottom:1.5rem;padding:1rem}.alerts-banner svg{color:#92400e;flex-shrink:0}.alerts-content strong{color:#92400e;display:block;margin-bottom:.25rem}.alerts-list{color:#78350f;display:flex;flex-direction:column;font-size:.85rem;gap:.25rem}.watchlist-layout{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:250px 1fr;min-height:500px}.watchlist-sidebar{background:#fff;background:var(--bg-card,#fff);border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);border-radius:12px;padding:1rem}.watchlist-sidebar h3{color:#6b7280;color:var(--text-secondary,#6b7280);font-size:.9rem;font-weight:600;letter-spacing:.05em;margin:0 0 1rem;text-transform:uppercase}.empty-lists{color:#9ca3af;color:var(--text-muted,#9ca3af);padding:2rem 1rem;text-align:center}.empty-lists svg,.watchlist-item{margin-bottom:.5rem}.watchlist-item{align-items:center;border-radius:8px;cursor:pointer;display:flex;gap:.75rem;padding:.75rem;transition:all .2s ease}.watchlist-item:hover{background:#f3f4f6;background:var(--bg-secondary,#f3f4f6)}.watchlist-item.active{background:#3b82f61a;border:1px solid #3b82f6;border:1px solid var(--primary-color,#3b82f6)}.item-color{border-radius:4px;flex-shrink:0;height:12px;width:12px}.item-info{flex:1 1;min-width:0}.item-name{color:#1f2937;color:var(--text-primary,#1f2937);display:block;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.item-count{color:#6b7280;color:var(--text-secondary,#6b7280);font-size:.75rem}.watchlist-item .delete-btn{background:#0000;border:none;color:#9ca3af;color:var(--text-muted,#9ca3af);cursor:pointer;opacity:0;padding:.25rem;transition:all .2s ease}.watchlist-item:hover .delete-btn{opacity:1}.watchlist-item .delete-btn:hover{color:#ef4444}.watchlist-content{background:#fff;background:var(--bg-card,#fff);border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);border-radius:12px;padding:1.25rem}.content-header{align-items:center;border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color,#e5e7eb);display:flex;justify-content:space-between;margin-bottom:1rem;padding-bottom:1rem}.content-header h3{font-size:1.1rem;font-weight:600;margin:0}.add-item-btn{align-items:center;background:#3b82f6;background:var(--primary-color,#3b82f6);border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:.85rem;font-weight:500;gap:.35rem;padding:.5rem 1rem}.add-item-btn:hover{opacity:.9}.empty-content{padding:4rem 2rem;text-align:center}.empty-content svg{color:#9ca3af;color:var(--text-muted,#9ca3af);margin-bottom:1rem}.empty-content h3{margin:0 0 .5rem}.empty-content p{color:#6b7280;color:var(--text-secondary,#6b7280);margin-bottom:1.5rem}.empty-content button{align-items:center;background:#3b82f6;background:var(--primary-color,#3b82f6);border:none;border-radius:8px;color:#fff;cursor:pointer;display:inline-flex;font-weight:500;gap:.5rem;padding:.6rem 1.2rem}.items-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}.stock-card{background:#f9fafb;background:var(--bg-secondary,#f9fafb);border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);border-radius:10px;padding:1rem;transition:all .2s ease}.stock-card:hover{box-shadow:0 4px 12px #00000014}.card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.75rem}.ticker{color:#1f2937;color:var(--text-primary,#1f2937);font-size:1.1rem;font-weight:700}.card-actions{align-items:center;display:flex;gap:.5rem}.card-actions .alert-on{color:#f59e0b}.card-actions .alert-off,.card-actions button{color:#9ca3af;color:var(--text-muted,#9ca3af)}.card-actions button{background:#0000;border:none;cursor:pointer;padding:.25rem}.card-actions button:hover{color:#ef4444}.card-price{align-items:baseline;display:flex;gap:.75rem;margin-bottom:.75rem}.current-price{color:#1f2937;color:var(--text-primary,#1f2937);font-size:1.25rem;font-weight:700}.price-change{align-items:center;display:flex;font-size:.85rem;font-weight:500;gap:.25rem}.price-change.positive{color:#10b981}.price-change.negative{color:#ef4444}.card-targets{flex-direction:column;margin-bottom:.75rem}.card-targets,.target{display:flex;gap:.35rem}.target{align-items:center;background:#fff;background:var(--bg-card,#fff);border-radius:4px;font-size:.8rem;padding:.35rem .5rem}.target.buy{color:#10b981}.target.sell{color:#ef4444}.target.triggered{animation:pulse 1s infinite;font-weight:600}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.target .distance{font-weight:500;margin-left:auto}.card-notes{border-top:1px solid #e5e7eb;border-top:1px solid var(--border-color,#e5e7eb);color:#6b7280;color:var(--text-secondary,#6b7280);font-size:.8rem;padding-top:.5rem}.modal-overlay{background:#00000080}.modal{background:#fff;background:var(--bg-card,#fff);border-radius:16px;max-height:90vh;max-width:450px;overflow-y:auto;width:100%}.modal-header{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color,#e5e7eb);padding:1.25rem}.modal-header h3{font-size:1.15rem;font-weight:600}.modal-header button{background:#0000;color:#6b7280;color:var(--text-secondary,#6b7280)}.modal form{padding:1.25rem}.form-group{margin-bottom:1rem}.form-group label{font-size:.85rem;margin-bottom:.35rem}.form-group input,.form-group textarea{border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);border-radius:8px;font-size:.95rem;padding:.6rem .85rem;width:100%}.form-group input:focus,.form-group textarea:focus{border-color:#3b82f6;border-color:var(--primary-color,#3b82f6);outline:none}.color-picker button{border:2px solid #0000;border-radius:8px;cursor:pointer;height:32px;transition:all .2s ease;width:32px}.color-picker button.selected{border-color:#1f2937;border-color:var(--text-primary,#1f2937);transform:scale(1.1)}.modal-actions{border-top:1px solid #e5e7eb;border-top:1px solid var(--border-color,#e5e7eb);display:flex;gap:.75rem;justify-content:flex-end;margin-top:1rem;padding-top:1rem}.modal-actions button{border-radius:8px;cursor:pointer;font-weight:500;padding:.6rem 1.2rem}.modal-actions button:first-child{background:#f3f4f6;background:var(--bg-secondary,#f3f4f6);border:none;color:#1f2937;color:var(--text-primary,#1f2937)}.modal-actions button.primary{background:#3b82f6;background:var(--primary-color,#3b82f6);border:none;color:#fff}.watchlist-loading{align-items:center;color:#6b7280;color:var(--text-secondary,#6b7280);display:flex;flex-direction:column;gap:1rem;justify-content:center;padding:3rem}.watchlist-loading .spin{animation:spin 1s linear infinite}@media (max-width:768px){.watchlist-layout{grid-template-columns:1fr}.watchlist-sidebar{order:2}.form-row{grid-template-columns:1fr}}.report-generator{margin:0 auto;max-width:900px;padding:1rem}.report-header{margin-bottom:2rem;text-align:center}.report-header h2{align-items:center;color:#1f2937;color:var(--text-primary,#1f2937);display:inline-flex;font-size:1.75rem;font-weight:700;gap:.75rem;margin:0 0 .5rem}.subtitle{color:#6b7280;color:var(--text-secondary,#6b7280);font-size:1rem;margin:0}.generator-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(350px,1fr))}.config-card{background:#fff;background:var(--bg-card,#fff);border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);border-radius:12px;box-shadow:0 4px 6px -1px #0000000d;overflow:hidden}.config-card .card-header{align-items:center;background:#f9fafb;background:var(--bg-secondary,#f9fafb);border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color,#e5e7eb);display:flex;gap:.75rem;padding:1.25rem}.config-card .card-header h3{color:#1f2937;color:var(--text-primary,#1f2937);font-size:1.1rem;font-weight:600;margin:0}.config-body{padding:1.5rem}.form-group label,.form-group select{color:#1f2937;color:var(--text-primary,#1f2937)}.form-group select{background-color:#fff;background-color:var(--bg-input,#fff);border:1px solid #d1d5db;border:1px solid var(--border-color,#d1d5db);border-radius:8px;font-size:.95rem;padding:.6rem;width:100%}.type-buttons{background:#f3f4f6;background:var(--bg-secondary,#f3f4f6);border-radius:8px;display:flex;gap:.5rem;padding:.25rem}.type-buttons button{background:#0000;border:none;border-radius:6px;color:#6b7280;color:var(--text-secondary,#6b7280);cursor:pointer;flex:1 1;font-size:.9rem;font-weight:500;padding:.5rem;transition:all .2s ease}.type-buttons button.active{background:#fff;background:var(--bg-card,#fff);box-shadow:0 1px 3px #0000001a;color:#3b82f6;color:var(--primary-color,#3b82f6)}.report-preview-info{background:#f9fafb;background:var(--bg-secondary,#f9fafb);border:1px dashed #e5e7eb;border:1px dashed var(--border-color,#e5e7eb);border-radius:8px;margin:1.5rem 0;padding:1rem}.report-preview-info h4{color:#1f2937;color:var(--text-primary,#1f2937);font-size:.9rem;margin:0 0 .5rem}.report-preview-info ul{margin:0;padding-left:1.25rem}.report-preview-info li{color:#6b7280;color:var(--text-secondary,#6b7280);font-size:.85rem;margin-bottom:.25rem}.generate-btn{align-items:center;background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:.5rem;justify-content:center;padding:.75rem;transition:all .2s ease;width:100%}.generate-btn:hover:not(:disabled){box-shadow:0 4px 12px #10b98166;transform:translateY(-1px)}.generate-btn:disabled{cursor:not-allowed;opacity:.7}.export-option{align-items:center;display:flex;justify-content:space-between;padding:.5rem 0}.export-info h4{color:#1f2937;color:var(--text-primary,#1f2937);font-size:1rem;margin:0 0 .25rem}.export-info p{margin:0}.export-info p,.year-select-sm{color:#6b7280;color:var(--text-secondary,#6b7280);font-size:.85rem}.year-select-sm{align-items:center;display:flex;gap:.5rem;margin-top:.5rem}.year-select-sm select{border-radius:4px;font-size:.85rem;padding:.25rem .5rem}.export-btn,.year-select-sm select{border:1px solid #d1d5db;border:1px solid var(--border-color,#d1d5db)}.export-btn{align-items:center;background:#f3f4f6;background:var(--bg-secondary,#f3f4f6);border-radius:6px;color:#1f2937;color:var(--text-primary,#1f2937);cursor:pointer;display:flex;font-weight:500;gap:.5rem;padding:.5rem 1rem;transition:all .2s ease}.export-btn:hover:not(:disabled){background:#e5e7eb;background:var(--bg-hover,#e5e7eb);border-color:#9ca3af;border-color:var(--text-secondary,#9ca3af)}.divider{background:#e5e7eb;background:var(--border-color,#e5e7eb);height:1px;margin:1.25rem 0}.note-box{background:#eff6ff;border-radius:8px;display:flex;gap:.75rem;margin-top:1.5rem;padding:.75rem}.note-box svg{color:#3b82f6;flex-shrink:0;margin-top:2px}.note-box p{color:#1e40af;font-size:.85rem;line-height:1.4;margin:0}.alert{align-items:center;border-radius:8px;display:flex;font-weight:500;gap:.75rem;margin-bottom:1.5rem;padding:1rem}.alert.error{background:#fef2f2;border:1px solid #fecaca;color:#b91c1c}.alert.success{background:#ecfdf5;border:1px solid #a7f3d0;color:#047857}@media (max-width:768px){.generator-grid{grid-template-columns:1fr}}.enhanced-charts{margin:0;padding:0 1rem 1rem;width:100%}.charts-header-section{align-items:center;background:#fff;background:var(--card-bg,#fff);border:1px solid #e2e8f0;border:1px solid var(--border-color,#e2e8f0);border-radius:16px;box-shadow:0 4px 20px #0000000d;box-shadow:0 4px 20px var(--card-shadow,#0000000d);display:flex;gap:1.5rem;justify-content:space-between;margin-bottom:1.5rem;overflow:hidden;padding:1.25rem 2rem;position:relative}.charts-header-section:before{background:linear-gradient(135deg,#6366f1,#8b5cf6);content:"";height:4px;left:0;position:absolute;right:0;top:0}.header-left{align-items:center;display:flex;gap:1.5rem}.header-icon-wrapper{flex-shrink:0}.header-icon{align-items:center;background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:12px;box-shadow:0 4px 12px #6366f14d;color:#fff;display:flex;height:48px;justify-content:center;width:48px}.header-title-content h2{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,var(--text-primary) 0,#6366f1 100%);-webkit-background-clip:text;background-clip:text;color:var(--text-primary);font-size:1.5rem;font-weight:700;margin:0 0 .25rem}.header-title-content p{color:var(--text-secondary);font-size:.875rem;margin:0}.chart-toggles{background:#f3f4f6;background:var(--bg-secondary,#f3f4f6);border-radius:8px;display:flex;gap:.25rem;padding:.25rem}.chart-toggles button{align-items:center;background:#0000;border:none;border-radius:6px;color:#6b7280;color:var(--text-secondary,#6b7280);cursor:pointer;display:flex;font-size:.9rem;font-weight:500;gap:.5rem;padding:.5rem 1rem;transition:all .2s ease}.chart-toggles button:hover{color:#1f2937;color:var(--text-primary,#1f2937)}.chart-toggles button.active{background:#fff;background:var(--bg-card,#fff);box-shadow:0 1px 3px #0000001a;color:#3b82f6;color:var(--primary-color,#3b82f6)}.chart-container-card{background:#fff;background:var(--bg-card,#fff);border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);border-radius:12px;box-shadow:0 4px 6px -1px #0000000d;padding:1.5rem}.chart-controls{align-items:center;border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color,#e5e7eb);display:flex;justify-content:space-between;margin-bottom:2rem;padding-bottom:1rem}.chart-controls h3{color:#1f2937;color:var(--text-primary,#1f2937);font-size:1.1rem;font-weight:600;margin:0}.total-value{color:#3b82f6;color:var(--primary-color,#3b82f6);font-size:1.1rem;font-weight:700;margin:0}.period-selector{display:flex;gap:.5rem}.period-selector button{background:#0000;border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);border-radius:6px;color:#6b7280;color:var(--text-secondary,#6b7280);cursor:pointer;font-size:.85rem;padding:.35rem .75rem;transition:all .2s ease}.period-selector button:hover{color:#3b82f6;color:var(--primary-color,#3b82f6)}.period-selector button.active,.period-selector button:hover{border-color:#3b82f6;border-color:var(--primary-color,#3b82f6)}.period-selector button.active{background:#3b82f6;background:var(--primary-color,#3b82f6);color:#fff}.chart-wrapper{min-height:400px;width:100%}.no-data,.pie-wrapper{align-items:center;display:flex;justify-content:center}.no-data{color:#9ca3af;color:var(--text-muted,#9ca3af);font-size:1.1rem;height:300px}.custom-tooltip{background:#fffffff2;border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);border-radius:8px;box-shadow:0 4px 12px #0000001a;padding:.75rem}.tooltip-label{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color,#e5e7eb);color:#1f2937;color:var(--text-primary,#1f2937);font-size:.9rem;font-weight:600;margin:0 0 .5rem;padding-bottom:.25rem}.custom-tooltip p{font-size:.85rem;margin:.25rem 0}.charts-loading{align-items:center;color:#6b7280;color:var(--text-secondary,#6b7280);display:flex;flex-direction:column;gap:1rem;justify-content:center;padding:4rem}.charts-loading .spin{animation:spin 1s linear infinite}@media (max-width:768px){.charts-header{align-items:flex-start;flex-direction:column}.chart-toggles{justify-content:space-between;overflow-x:auto;width:100%}.chart-controls{align-items:flex-start;flex-direction:column;gap:1rem}.period-selector{justify-content:space-between;overflow-x:auto;width:100%}}.portfolio-enhanced-tab{display:flex;flex-direction:column;min-height:100%}.enhanced-tab-nav{-webkit-overflow-scrolling:touch;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:16px;display:flex;gap:.5rem;margin-bottom:1.5rem;overflow-x:auto;padding:.75rem}.enhanced-tab-nav::-webkit-scrollbar{height:4px}.enhanced-tab-nav::-webkit-scrollbar-track{background:#0000}.enhanced-tab-nav::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}.tab-btn{align-items:center;background:#0000;border:none;border-radius:12px;color:var(--text-secondary);cursor:pointer;display:flex;font-size:.9rem;font-weight:500;gap:.5rem;padding:.75rem 1.25rem;transition:all .2s ease;white-space:nowrap}.tab-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.tab-btn.active{background:#6366f1;background:var(--primary-color,#6366f1);box-shadow:0 4px 12px #6366f14d;color:#fff}.tab-btn.active svg{color:#fff}.enhanced-tab-content{flex:1 1;min-height:0}@media (max-width:768px){.enhanced-tab-nav{border-radius:12px;gap:.25rem;padding:.5rem}.tab-btn{border-radius:8px;font-size:.85rem;padding:.6rem .8rem}.tab-btn span{display:none}.tab-btn svg{margin:0}}@media (min-width:769px){.enhanced-tab-nav{flex-wrap:wrap;justify-content:center}}.portfolio-enhanced-page{background:var(--bg-primary);color:var(--text-primary);min-height:100vh;padding:1.5rem}.page-header{display:flex;flex-direction:column;gap:1rem;margin:0 0 1.5rem}.back-link{align-items:center;background:var(--bg-secondary);border-radius:8px;color:var(--text-secondary);display:inline-flex;font-size:.9rem;font-weight:500;gap:.5rem;padding:.5rem 1rem;text-decoration:none;transition:all .2s ease;width:-webkit-fit-content;width:fit-content}.back-link:hover{background:var(--bg-tertiary);color:var(--primary-color);transform:translateX(-4px)}.page-header h1{color:var(--primary-color);font-size:2rem;font-weight:700;margin:0}.page-content{background:var(--bg-card);border:1px solid var(--border-color);border-radius:20px;box-shadow:0 4px 24px var(--shadow-color);min-height:calc(100vh - 200px);padding:1.5rem}@media (max-width:768px){.portfolio-enhanced-page{padding:1rem}.page-content{border-radius:16px;padding:1rem}.page-header h1{font-size:1.5rem}.back-link{font-size:.85rem;padding:.4rem .75rem}}.content-manager{margin:0 auto;max-width:1200px;padding:1.5rem}.content-manager-loading{align-items:center;color:var(--text-secondary);display:flex;flex-direction:column;gap:1rem;justify-content:center;min-height:400px}.content-manager-loading .spin{animation:spin 1s linear infinite}.cm-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.5rem}.cm-header h2{color:var(--text-primary);font-size:1.5rem;font-weight:700;margin:0}.cm-btn{align-items:center;border:none;border-radius:10px;cursor:pointer;display:inline-flex;font-size:.9rem;font-weight:600;gap:.5rem;padding:.75rem 1.25rem;transition:all .2s}.cm-btn.primary{background:linear-gradient(135deg,var(--primary-color),#8b5cf6);color:#fff}.cm-btn.primary:hover{box-shadow:0 4px 12px #6366f14d;transform:translateY(-2px)}.cm-btn.secondary{background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-primary)}.cm-btn.secondary:hover{background:var(--bg-tertiary)}.cm-btn:disabled{cursor:not-allowed;opacity:.6}.cm-message{align-items:center;border-radius:10px;display:flex;font-size:.9rem;justify-content:space-between;margin-bottom:1rem;padding:.75rem 1rem}.cm-message.success{background:#10b9811a;border:1px solid #10b98133;color:#10b981}.cm-message.error{background:#ef44441a;border:1px solid #ef444433;color:#ef4444}.cm-message button{background:none;border:none;color:inherit;cursor:pointer;padding:.25rem}.cm-tabs{background:var(--bg-secondary);border-radius:12px;margin-bottom:1.5rem;padding:.5rem}.cm-tab,.cm-tabs{display:flex;gap:.5rem}.cm-tab{align-items:center;background:#0000;border:none;border-radius:10px;color:var(--text-secondary);cursor:pointer;font-size:.95rem;font-weight:500;padding:.75rem 1.5rem;transition:all .2s}.cm-tab:hover{background:var(--bg-tertiary);color:var(--text-primary)}.cm-tab.active{background:linear-gradient(135deg,var(--primary-color),#8b5cf6);color:#fff}.tab-count{background:#fff3;border-radius:10px;font-size:.8rem;padding:.15rem .5rem}.cm-content,.cm-tab:not(.active) .tab-count{background:var(--bg-card)}.cm-content{border:1px solid var(--border-color);border-radius:16px;overflow:hidden}.cm-list{padding:1rem}.cm-empty{align-items:center;color:var(--text-secondary);display:flex;flex-direction:column;padding:4rem 2rem;text-align:center}.cm-empty svg{margin-bottom:1rem;opacity:.5}.cm-empty h3{color:var(--text-primary);font-size:1.25rem;margin-bottom:.5rem}.cm-empty p{margin-bottom:1.5rem}.cm-item{align-items:flex-start;background:var(--bg-secondary);border-radius:12px;display:flex;gap:1rem;margin-bottom:.75rem;padding:1rem;transition:all .2s}.cm-item:last-child{margin-bottom:0}.cm-item:hover{background:var(--bg-tertiary)}.cm-item.inactive{opacity:.5}.item-image{background:var(--bg-tertiary);border-radius:8px;flex-shrink:0;height:70px;overflow:hidden;width:100px}.item-image img{height:100%;object-fit:cover;width:100%}.item-image .no-image{align-items:center;color:var(--text-muted);display:flex;height:100%;justify-content:center;width:100%}.item-content{flex:1 1;min-width:0}.item-header{align-items:center;display:flex;gap:.5rem;margin-bottom:.35rem}.item-header h4{color:var(--text-primary);font-size:1rem;font-weight:600;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.item-badge{border-radius:6px;color:#fff;font-size:.7rem;font-weight:600;padding:.2rem .5rem;text-transform:uppercase}.item-desc{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:var(--text-secondary);display:-webkit-box;font-size:.85rem;margin:0 0 .5rem;overflow:hidden}.item-meta{color:var(--text-muted);display:flex;font-size:.75rem;gap:1rem}.item-actions{display:flex;gap:.25rem}.item-actions button{align-items:center;background:var(--bg-card);border:none;border-radius:8px;color:var(--text-secondary);cursor:pointer;display:flex;height:36px;justify-content:center;transition:all .2s;width:36px}.item-actions button:hover{background:var(--primary-color);color:#fff}.item-actions button.danger:hover{background:#ef4444}.changelog-item{flex-direction:column}.changelog-header{align-items:center;display:flex;gap:.75rem;margin-bottom:.5rem}.changelog-type{align-items:center;border-radius:6px;color:#fff;display:inline-flex;font-size:.75rem;font-weight:600;gap:.25rem;padding:.25rem .6rem;text-transform:capitalize}.changelog-version{background:#6366f11a;border-radius:6px;color:var(--primary-color);font-size:.85rem;font-weight:700;padding:.2rem .6rem}.changelog-date{color:var(--text-muted);font-size:.8rem}.changelog-title{color:var(--text-primary);font-size:1rem;font-weight:600;margin:0 0 .5rem}.changelog-highlights{list-style:none;margin:0;padding-left:1.25rem}.changelog-highlights li{color:var(--text-secondary);font-size:.85rem;margin-bottom:.25rem;position:relative}.changelog-highlights li:before{color:var(--primary-color);content:"•";left:-1rem;position:absolute}.changelog-highlights li.more{color:var(--primary-color);font-weight:500}.changelog-item .item-actions{align-self:flex-end;margin-top:.75rem}.cm-modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000}.cm-modal{background:#fff;background:var(--bg-card,#fff);border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);border-radius:20px;box-shadow:0 20px 60px #0006;display:flex;flex-direction:column;max-height:90vh;max-width:600px;overflow:hidden;width:100%}@media (prefers-color-scheme:dark){.cm-modal{background:#1f2937;background:var(--bg-card,#1f2937)}}.dark .cm-modal,[data-theme=dark] .cm-modal{background:#1f2937;background:var(--bg-card,#1f2937)}.modal-header{align-items:center;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:1.25rem 1.5rem}.modal-header h3{color:var(--text-primary);font-size:1.25rem;font-weight:700;margin:0}.modal-header button{background:none;border:none;border-radius:8px;color:var(--text-secondary);cursor:pointer;padding:.25rem;transition:all .2s}.modal-header button:hover{background:var(--bg-secondary);color:var(--text-primary)}.modal-body{flex:1 1;overflow-y:auto;padding:1.5rem}.modal-footer{border-top:1px solid var(--border-color);display:flex;gap:.75rem;justify-content:flex-end;padding:1rem 1.5rem}.form-group{margin-bottom:1.25rem}.form-group label{font-size:.9rem}.form-group input[type=date],.form-group input[type=number],.form-group input[type=text],.form-group select,.form-group textarea{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:10px;color:var(--text-primary);font-size:.95rem;padding:.75rem 1rem;transition:all .2s;width:100%}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px #6366f11a;outline:none}.form-group textarea{min-height:80px;resize:vertical}.form-row{grid-gap:1rem;gap:1rem}.form-group.checkbox label{align-items:center;cursor:pointer;display:flex;gap:.5rem}.form-group.checkbox input[type=checkbox]{width:auto}.image-upload{width:100%}.upload-area{align-items:center;border:2px dashed var(--border-color);border-radius:12px;color:var(--text-secondary);cursor:pointer;display:flex;flex-direction:column;justify-content:center;padding:2rem;text-align:center;transition:all .2s}.upload-area:hover{background:#6366f10d;border-color:var(--primary-color)}.upload-area svg{margin-bottom:.5rem}.upload-area span{font-weight:500}.upload-area small{color:var(--text-muted);font-size:.8rem;margin-top:.25rem}.image-preview{border-radius:12px;height:150px;overflow:hidden;position:relative;width:100%}.image-preview img{height:100%;object-fit:cover;width:100%}.image-preview .remove-image{align-items:center;background:#0009;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;height:28px;justify-content:center;position:absolute;right:.5rem;top:.5rem;width:28px}.image-preview .remove-image:hover{background:#ef4444}.color-picker{display:flex;gap:.5rem}.color-picker input[type=color]{border:none;border-radius:8px;cursor:pointer;height:42px;padding:0;width:50px}.color-picker input[type=text]{flex:1 1}.highlight-row{display:flex;gap:.5rem;margin-bottom:.5rem}.highlight-row input{flex:1 1}.highlight-row button{align-items:center;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-secondary);cursor:pointer;display:flex;height:42px;justify-content:center;width:36px}.highlight-row button:hover{background:#ef4444;border-color:#ef4444;color:#fff}.add-highlight{align-items:center;background:#0000;border:1px dashed var(--border-color);border-radius:8px;color:var(--primary-color);cursor:pointer;display:inline-flex;font-size:.9rem;gap:.5rem;padding:.5rem 1rem;transition:all .2s}.add-highlight:hover{background:#6366f11a;border-color:var(--primary-color)}@media (max-width:768px){.content-manager{padding:1rem}.cm-header{align-items:stretch;gap:1rem}.cm-header,.cm-item,.cm-tabs{flex-direction:column}.item-image{height:120px;width:100%}.form-row{grid-template-columns:1fr}.modal-footer{flex-direction:column}.modal-footer .cm-btn{justify-content:center;width:100%}}.admin-container{background:var(--bg-primary);margin:0 auto;max-width:100%;padding:2rem 1.5rem;width:100%}.admin-header{margin-bottom:2rem}.admin-header h1{color:var(--text-primary);font-size:2rem;margin-bottom:.5rem}.admin-header p{color:var(--text-secondary);font-size:1rem}.admin-section{background:var(--card-bg);border:1px solid var(--card-border);border-radius:12px;box-shadow:0 2px 8px var(--card-shadow);margin-bottom:2rem;padding:2rem}.section-header{border-bottom:2px solid var(--border-color);margin-bottom:1.5rem;padding-bottom:1rem}.section-header h2{font-size:1.5rem}.status-indicator{align-items:center;border-radius:20px;display:inline-flex;font-size:.9rem;font-weight:500;gap:.5rem;padding:.5rem 1rem}.status-indicator.online{background:var(--success-light);color:var(--success-color)}.status-indicator.offline{background:var(--error-light);color:var(--error-color)}.form-group{margin-bottom:1.5rem}.form-group label{display:block;font-weight:500;margin-bottom:.5rem}.form-group input,.form-group select{background:var(--bg-primary);border:2px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-size:1rem;padding:.75rem;transition:border-color .3s;width:100%}.form-group input:focus,.form-group select:focus{border-color:var(--success-color);outline:none}.form-group input[type=checkbox]{margin-right:.5rem;width:auto}.form-row{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:1fr 1fr}@media (max-width:768px){.form-row{grid-template-columns:1fr}}.save-btn{border-radius:8px;font-size:1rem;padding:1rem 2rem;transition:background .3s}.save-btn:hover{background:var(--success-color);filter:brightness(1.1)}.save-btn:disabled{background:var(--text-tertiary)}.test-btn{background:var(--info-color);border:none;border-radius:8px;color:#fff;font-size:.9rem;font-weight:600;padding:.75rem 1.5rem;transition:background .3s}.test-btn:hover{background:var(--primary-hover)}.connection-status{align-items:center;border-radius:8px;display:flex;gap:.5rem;margin-top:1rem;padding:1rem}.connection-status.success{background:var(--success-light);color:var(--success-color)}.connection-status.error{background:var(--error-light);color:var(--error-color)}.scraping-controls{display:flex;gap:1rem;margin-top:1.5rem}.scraping-btn{border:none;border-radius:8px;cursor:pointer;font-weight:600;padding:.75rem 1.5rem;transition:all .3s}.scraping-btn.start{background:var(--success-color);color:#fff}.scraping-btn.start:hover{background:var(--success-color);filter:brightness(1.1)}.scraping-btn.stop{background:var(--error-color);color:#fff}.scraping-btn.stop:hover{background:var(--error-color);filter:brightness(.9)}.scraping-btn:disabled{background:var(--text-tertiary);cursor:not-allowed}.loading{opacity:.6;pointer-events:none}.error-message{background:var(--error-light);border:1px solid var(--error-color);border-radius:8px;color:var(--error-color);margin-top:1rem;padding:1rem}.success-message{background:var(--success-light);border:1px solid var(--success-color);border-radius:8px;color:var(--success-color);margin-top:1rem;padding:1rem}.ticker-config{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;margin-top:1rem;padding:1.5rem}.ticker-input{background:var(--bg-primary);border:2px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-size:1rem;margin-bottom:1rem;padding:.75rem;width:100%}.ticker-list{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1rem}.ticker-chip{background:var(--info-color);border-radius:20px;font-size:.9rem;gap:.5rem;padding:.5rem 1rem}.remove-ticker,.ticker-chip{align-items:center;color:#fff;display:flex}.remove-ticker{background:var(--bg-glass-light);border:none;border-radius:50%;cursor:pointer;font-weight:700;height:20px;justify-content:center;width:20px}.telegram-test-section{margin-top:1rem}.telegram-test-btn{background:var(--info-color);border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:600;margin-top:1rem;padding:.75rem 1.5rem;transition:background .3s;width:100%}.telegram-test-btn:hover:not(:disabled){background:var(--primary-hover)}.telegram-test-btn:disabled{background:var(--text-tertiary);cursor:not-allowed}.subscription-badge{align-items:center;border:1px solid #0000;border-radius:8px;display:inline-flex;font-size:.8125rem;font-weight:600;gap:.5rem;letter-spacing:.3px;padding:.5rem 1rem;text-transform:capitalize;transition:all .2s ease;white-space:nowrap}.badge-small{font-size:.75rem;gap:.375rem;padding:.375rem .75rem}.badge-medium{font-size:.875rem;gap:.5rem;padding:.625rem 1.25rem}.badge-ultimate{background:var(--warning-color);border-color:var(--warning-color);box-shadow:0 2px 8px #ffc1074d;color:#fff}.badge-ultimate:hover{background:var(--warning-hover);box-shadow:0 4px 12px #ffc10766;transform:translateY(-1px)}.badge-premium{background:var(--primary-color);border-color:var(--primary-color);box-shadow:0 2px 8px #2962ff4d;color:#fff}.badge-premium:hover{background:var(--primary-hover);box-shadow:0 4px 12px #2962ff66;transform:translateY(-1px)}.badge-admin{background:var(--error-color);border-color:var(--error-color);box-shadow:0 2px 8px #ef53504d;color:#fff}.badge-admin:hover{background:var(--error-hover);box-shadow:0 4px 12px #ef535066;transform:translateY(-1px)}.badge-free{background:var(--bg-secondary);border-color:var(--border-color);box-shadow:0 1px 4px var(--card-shadow);color:var(--text-secondary)}.badge-free:hover{background:var(--bg-tertiary);box-shadow:0 2px 8px var(--card-shadow)}.badge-large{border-radius:10px;font-size:1rem;gap:.625rem;padding:.75rem 1.5rem}.subscription-badge svg{flex-shrink:0}.subscribe-button-container{display:flex;flex-direction:column;gap:.5rem;width:100%}.subscribe-button{align-items:center;background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;border-radius:12px;box-shadow:0 4px 15px #6366f14d;color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:.75rem;justify-content:center;padding:1rem 1.5rem;transition:all .3s ease;width:100%}.subscribe-button:hover:not(:disabled){box-shadow:0 6px 20px #6366f166;transform:translateY(-2px)}.subscribe-button:active:not(:disabled){transform:translateY(0)}.subscribe-button:disabled{cursor:not-allowed;opacity:.6;transform:none}.subscribe-button.processing{background:linear-gradient(135deg,#94a3b8,#64748b)}.subscribe-button svg{flex-shrink:0}.subscribe-button .spinner{animation:spin 1s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:20px;width:20px}.subscribe-error{background:#ef44441a;border:1px solid #ef44444d;color:#ef4444;padding:.75rem}.subscribe-error,.subscribe-login-hint{border-radius:8px;font-size:.875rem;text-align:center}.subscribe-login-hint{background:#6366f11a;color:#64748b;color:var(--text-secondary,#64748b);padding:.5rem}.subscribe-button.with-icon{background:#000}.subscribe-button.with-icon:hover:not(:disabled){background:#1a1a1a}.subscribe-button.xendit{background:linear-gradient(135deg,#06f,#05d);box-shadow:0 4px 15px #0066ff4d}.subscribe-button.xendit:hover:not(:disabled){box-shadow:0 6px 20px #06f6}.subscribe-button.midtrans{background:linear-gradient(135deg,#00aa5b,#008f4d);box-shadow:0 4px 15px #00aa5b4d}.subscribe-button.midtrans:hover:not(:disabled){box-shadow:0 6px 20px #00aa5b66}.profile-container{background:var(--bg-primary);box-sizing:border-box;margin:0 auto;max-width:800px;min-height:100vh;padding:2rem 1.5rem;width:100%}@media (min-width:1200px){.profile-container{max-width:750px}}@media (min-width:1600px){.profile-container{max-width:700px}}.profile-header{border-bottom:1px solid var(--border-color);margin-bottom:2rem;padding-bottom:1.5rem;text-align:center}.header-top{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;margin-bottom:.5rem}.profile-header h1{color:var(--text-primary);font-size:1.75rem;font-weight:700;margin:0}.header-subtitle{color:var(--text-secondary);font-size:.9rem;margin:0}.message{align-items:center;border-radius:.5rem;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;margin-bottom:1.25rem;padding:.75rem 1rem}.message.success{background:var(--success-light);border:1px solid var(--success-color);color:var(--success-color)}.message.error{background:var(--error-light);border:1px solid var(--error-color);color:var(--error-color)}.profile-content{display:flex;flex-direction:column;gap:1.5rem;max-width:100%;width:100%}.profile-section{background:var(--card-bg);border:1px solid var(--card-border);border-radius:.75rem;box-shadow:0 2px 4px var(--card-shadow);box-sizing:border-box;padding:1.5rem;width:100%}.section-header{align-items:center;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;margin-bottom:1rem;padding-bottom:.75rem}.section-header h2{color:var(--text-primary);font-size:1.125rem;font-weight:600;margin:0}.edit-btn{align-items:center;background:var(--info-color);border:none;border-radius:.5rem;color:#fff;cursor:pointer;display:flex;font-size:.8125rem;font-weight:500;gap:.375rem;padding:.5rem .875rem;transition:all .2s ease}.edit-btn:hover:not(:disabled){background:var(--primary-hover);transform:translateY(-1px)}.edit-btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.profile-info{display:flex;flex-direction:column;gap:.875rem}.info-item{align-items:center;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:.5rem;box-sizing:border-box;display:flex;gap:1rem;justify-content:space-between;padding:.75rem 1rem;width:100%}@media (min-width:1200px){.info-item{max-width:100%}.info-value{flex:1 1;justify-content:flex-end;text-align:right}.info-value input{max-width:300px}}.info-label{color:var(--text-secondary);min-width:140px}.info-label,.info-value{align-items:center;display:flex;font-size:.875rem;font-weight:500;gap:.5rem}.info-value,.info-value input{color:var(--text-primary)}.info-value input{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:.375rem;font-size:.875rem;padding:.5rem .75rem;transition:border-color .2s ease;width:220px}.info-value input:focus{border-color:var(--info-color);outline:none}.verified-badge{background:var(--success-light);border-radius:.25rem;color:var(--success-color);font-size:.75rem;font-weight:500;padding:.1875rem .5rem}.connected-accounts{display:flex;flex-direction:column;gap:.875rem}.account-item{align-items:center;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:.5rem;display:flex;gap:1rem;justify-content:space-between;padding:1rem}.account-item .connect-btn{flex:0 0 auto!important;max-width:none!important;min-width:auto!important;white-space:nowrap!important;width:auto!important}.account-info{align-items:center;display:flex;gap:.75rem}.account-info h3{color:var(--text-primary);font-size:.9375rem;font-weight:600;margin:0 0 .125rem}.account-info p{color:var(--text-secondary);font-size:.8125rem;margin:0}.connect-btn{flex:0 0 auto!important;font-size:.8125rem;gap:.375rem;max-width:none!important;min-width:auto!important;padding:.5rem 1rem;transition:all .2s ease;white-space:nowrap!important;width:auto!important}.connect-btn.connected,.connect-btn.connected:hover{background:var(--success-color)}.connect-btn.connected:hover{filter:brightness(.9)}.connect-btn:disabled{opacity:.6;transform:none}.notification-settings{display:flex;flex-direction:column;gap:.875rem}.setting-item{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:.5rem;justify-content:space-between;padding:1rem}.setting-info,.setting-item{align-items:center;display:flex}.setting-info{flex:1 1;gap:.75rem}.setting-info h3{color:var(--text-primary);font-size:.9375rem;font-weight:600;margin:0 0 .125rem}.setting-info p{color:var(--text-secondary);font-size:.8125rem;margin:0}.setting-controls{gap:1rem}.input-group,.setting-controls{align-items:center;display:flex}.input-group{gap:.5rem}.input-group input{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:.375rem;color:var(--text-primary);font-size:.875rem;padding:.5rem .75rem;transition:border-color .2s ease;width:180px}.input-group input:focus{border-color:var(--info-color);outline:none}.bind-btn{align-items:center;background:var(--info-color);border:none;border-radius:.375rem;color:#fff;cursor:pointer;display:flex;font-size:.8125rem;font-weight:500;gap:.375rem;padding:.5rem .875rem;transition:all .2s ease}.bind-btn:hover:not(:disabled){background:var(--primary-hover)}.bind-btn:disabled{cursor:not-allowed;opacity:.6}.telegram-connect-group{display:flex;flex-direction:column;gap:1rem;width:100%}.telegram-connected{background:var(--success-light);border:1px solid var(--success-color);border-radius:.5rem;font-size:.875rem;padding:.75rem 1rem}.telegram-connected,.telegram-connected .connected-icon{color:var(--success-color)}.chat-id-badge{background:var(--success-color);border-radius:.25rem;color:#fff;font-family:monospace;font-size:.75rem;margin-left:auto;padding:.25rem .5rem}.refresh-btn{align-items:center;background:#0000;border:1px solid var(--success-color);border-radius:.25rem;color:var(--success-color);cursor:pointer;display:flex;flex-shrink:0;justify-content:center;padding:.375rem;transition:all .2s}.refresh-btn:hover:not(:disabled){background:var(--success-color);color:#fff}.refresh-btn:disabled{cursor:not-allowed;opacity:.5}.refresh-btn .spinning{animation:spin 1s linear infinite}.telegram-connect{flex-direction:column;gap:.75rem;width:100%}.connect-instruction{color:var(--text-secondary);font-size:.875rem;line-height:1.5;margin:0}.connect-btn{align-items:center;background:var(--info-color);border:none;border-radius:.5rem;color:#fff;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;justify-content:center;padding:.75rem 1.5rem;transition:all .2s;width:100%}.connect-btn:hover:not(:disabled){background:var(--primary-hover);box-shadow:0 4px 8px var(--primary-shadow);transform:translateY(-1px)}.connect-btn:disabled{cursor:not-allowed;opacity:.5}.logout-btn-profile{align-items:center;background:var(--error-color);border:none;border-radius:.5rem;color:#fff;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;padding:.75rem 1.5rem;transition:all .2s}.logout-btn-profile:hover:not(:disabled){background:var(--error-color);box-shadow:0 4px 12px var(--error-color);filter:brightness(.9);transform:translateY(-1px)}.logout-btn-profile:disabled{cursor:not-allowed;opacity:.5}.telegram-connect{align-items:center;display:flex;flex-direction:row;gap:.5rem}.copy-link-btn{align-items:center;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:.5rem;color:var(--text-secondary);cursor:pointer;display:flex;flex-shrink:0;justify-content:center;padding:.75rem;transition:all .2s}.copy-link-btn:hover{background:var(--bg-tertiary);border-color:var(--border-color-dark);color:var(--text-primary)}.setting-status{align-items:center;color:var(--text-secondary);font-size:.875rem;gap:.5rem}.setting-status .connected-icon{color:var(--success-color);flex-shrink:0}.setting-status{align-items:flex-end;display:flex;flex-direction:column;gap:.25rem}.setting-status span{color:var(--text-secondary);font-size:.8125rem;font-weight:500}.status-badge{background:var(--success-light);border-radius:.25rem;color:var(--success-color);font-size:.75rem;font-weight:500;padding:.1875rem .5rem}.qol-setting{background:var(--info-light);border:1px solid var(--info-color);border-radius:.5rem;margin-top:.75rem;padding:1rem}.checkbox-label{align-items:flex-start;cursor:pointer;display:flex;font-size:.8125rem;gap:.75rem}.checkbox-label input[type=checkbox]{display:none}.checkmark{align-items:center;border:2px solid var(--info-color);border-radius:.25rem;display:flex;flex-shrink:0;height:20px;justify-content:center;margin-top:.125rem;transition:all .2s ease;width:20px}.checkbox-label input[type=checkbox]:checked+.checkmark{background:var(--info-color);color:#fff}.checkbox-label input[type=checkbox]:checked+.checkmark:after{content:"✓";font-size:12px;font-weight:700}.checkbox-label div strong{color:var(--text-primary);display:block;font-size:.875rem;margin-bottom:.125rem}.checkbox-label div p{color:var(--text-secondary);font-size:.75rem;margin:0}.profile-actions{display:flex;justify-content:center;padding:1.25rem 0}.save-btn{align-items:center;background:var(--success-color);border:none;border-radius:.5rem;color:#fff;cursor:pointer;display:flex;font-size:.9375rem;font-weight:600;gap:.5rem;padding:.75rem 1.75rem;transition:all .2s ease}.save-btn:hover:not(:disabled){box-shadow:0 8px 25px var(--success-color);filter:brightness(1.1);transform:translateY(-2px)}.save-btn:disabled{cursor:not-allowed;opacity:.6;transform:none}@media (max-width:768px){.profile-container{padding:1rem}.profile-header h1{font-size:1.5rem}.profile-section{padding:1rem}.info-item{align-items:flex-start;flex-direction:column;gap:.5rem}.info-label{min-width:auto}.info-value input{width:100%}.setting-item{align-items:flex-start;flex-direction:column;gap:1rem}.setting-controls{justify-content:flex-start;width:100%}.input-group{width:100%}.input-group input{flex:1 1}.account-item{align-items:flex-start;flex-direction:column;gap:1rem}}.subscription-section{background:var(--card-bg);border:1px solid var(--card-border);border-radius:1rem;box-shadow:0 4px 12px var(--card-shadow);overflow:hidden;padding:1.75rem;position:relative}.subscription-section:before{background:linear-gradient(90deg,var(--primary-color),var(--secondary-color));content:"";height:4px;left:0;position:absolute;right:0;top:0}.subscription-section .section-header{align-items:center;border-bottom:1px solid var(--border-color);display:flex;gap:1rem;justify-content:space-between;margin-bottom:1.25rem;padding-bottom:1rem}.subscription-section .section-header h2{align-items:center;color:var(--text-primary);display:flex;font-size:1.125rem;font-weight:600;gap:.625rem;margin:0}.subscription-section .section-header h2 svg{color:var(--primary-color)}.subscription-details{grid-gap:.875rem;display:grid;gap:.875rem;grid-template-columns:repeat(2,1fr);margin-bottom:1.5rem}.subscription-details-modern{margin-bottom:1.5rem}.subscription-info-row{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:1fr 1fr;margin-bottom:1rem}.subscription-info-item{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:.75rem;display:flex;flex-direction:column;gap:.5rem;padding:1rem}.subscription-info-label{color:var(--text-secondary);font-size:.75rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.subscription-info-value{color:var(--text-primary);font-size:1.25rem;font-weight:700}.subscription-additional-info{border-top:1px solid var(--border-color);display:flex;flex-direction:column;gap:.75rem;padding-top:1rem}.detail-row{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:.75rem;display:flex;flex-direction:column;gap:.375rem;padding:1rem;transition:all .2s ease}.detail-row:hover{background:var(--bg-tertiary);border-color:var(--primary-color-alpha-01)}.detail-label{color:var(--text-secondary);font-size:.75rem;font-weight:500;letter-spacing:.5px;text-transform:uppercase}.detail-value{color:var(--text-primary);font-size:1rem;font-weight:600;text-transform:capitalize}.subscription-actions{display:flex;flex-wrap:wrap;gap:1rem;padding-top:.5rem}.btn-cancel,.btn-upgrade,.btn-upgrade-premium{align-items:center;border:none;border-radius:.75rem;cursor:pointer;display:flex;flex:1 1;font-size:.9rem;font-weight:600;gap:.5rem;justify-content:center;min-width:160px;padding:.875rem 1.5rem;transition:all .3s cubic-bezier(.175,.885,.32,1.275)}.btn-upgrade,.btn-upgrade-premium{background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));box-shadow:0 4px 12px var(--primary-shadow);color:#fff}.btn-upgrade-premium:hover:not(:disabled),.btn-upgrade:hover:not(:disabled){box-shadow:0 8px 24px var(--primary-shadow-hover);filter:brightness(1.05);transform:translateY(-3px)}.btn-cancel{background:var(--bg-secondary);border:2px solid var(--border-color);color:var(--text-secondary)}.btn-cancel:hover:not(:disabled){background:var(--error-light);border-color:var(--error-color);color:var(--error-color)}.btn-cancel:disabled,.btn-upgrade-premium:disabled,.btn-upgrade:disabled{cursor:not-allowed;opacity:.5;transform:none}.status-badge.status-active{background:var(--success-light);color:var(--success-color)}.status-badge.status-active,.status-badge.status-cancelled,.status-badge.status-expired{border-radius:.375rem;font-size:.75rem;font-weight:600;padding:.25rem .625rem;text-transform:capitalize}.status-badge.status-cancelled,.status-badge.status-expired{background:var(--error-light);color:var(--error-color)}.status-badge.status-pending{background:var(--warning-light);border-radius:.375rem;color:var(--warning-color);font-size:.75rem;font-weight:600;padding:.25rem .625rem;text-transform:capitalize}.admin-notice{align-items:center;background:linear-gradient(135deg,var(--info-light),var(--card-bg));border:2px solid var(--info-color);border-radius:.75rem;display:flex;gap:1rem;padding:1.5rem}.admin-notice .admin-icon{color:var(--info-color);flex-shrink:0}.admin-notice h3{color:var(--text-primary);font-size:1.125rem;font-weight:600;margin:0 0 .25rem}.admin-notice p{color:var(--text-secondary);font-size:.875rem;margin:0}@media (max-width:768px){.subscription-section{padding:1.25rem}.subscription-details{gap:.75rem;grid-template-columns:1fr}.subscription-actions{flex-direction:column;gap:.75rem}.btn-cancel,.btn-upgrade,.btn-upgrade-premium{min-width:auto;width:100%}.detail-row{padding:.875rem}.header-top{flex-direction:column;gap:.75rem}}.modal-overlay{background:#000c;padding:1rem;z-index:10000}.modal-content{background:var(--card-bg);border:1px solid var(--border-color);border-radius:16px;box-shadow:0 20px 60px #0000004d;max-height:90vh;max-width:900px;overflow-y:auto;padding:2rem;width:100%}.modal-content h2{color:var(--text-primary);font-size:1.75rem;font-weight:700;margin:0 0 1.5rem;text-align:center}.plans-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-bottom:2rem}.plan-card{background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:12px;padding:2rem;position:relative;transition:all .3s ease}.plan-card:hover{border-color:var(--primary-color);box-shadow:0 8px 24px var(--primary-shadow);transform:translateY(-4px)}.plan-card.popular{border-color:var(--primary-color);box-shadow:0 8px 32px var(--primary-shadow)}.plan-card.current{background:var(--success-light);border-color:var(--success-color)}.popular-badge{background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));border-radius:12px;color:#fff;font-size:.75rem;font-weight:600;padding:.25rem .75rem;position:absolute;right:1rem;top:-12px}.plan-card h3{color:var(--text-primary);font-size:1.5rem;font-weight:700;margin:0 0 1rem}.plan-price{margin-bottom:1.5rem}.plan-price .price{color:var(--text-primary);font-size:2rem;font-weight:800}.plan-price .period{color:var(--text-secondary);font-size:1rem;margin-left:.25rem}.plan-price .yearly-price{color:var(--text-secondary);font-size:.875rem;margin-top:.5rem}.plan-features{list-style:none;margin:0 0 1.5rem;padding:0}.plan-features li{align-items:center;color:var(--text-primary);display:flex;font-size:.9rem;gap:.5rem;padding:.5rem 0}.plan-features li svg{color:var(--success-color);flex-shrink:0}.btn-current{background:var(--success-color);border:none;border-radius:8px;color:#fff;cursor:default;font-size:.9rem;font-weight:600;padding:.875rem 1.5rem;width:100%}.subscribe-button-wrapper{width:100%}.subscribe-button-wrapper button{align-items:center;background:#000;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:.9rem;font-weight:600;gap:.5rem;justify-content:center;padding:.875rem 1.5rem;transition:all .3s ease;width:100%}.subscribe-button-wrapper button:hover:not(:disabled){background:#333;box-shadow:0 4px 12px #0000004d;transform:translateY(-2px)}.btn-close{background:#0000;border:none;border-radius:8px;color:var(--text-secondary);cursor:pointer;display:block;font-size:.875rem;margin:1rem auto 0;padding:.5rem 1.5rem;transition:all .2s ease}.btn-close:hover{background:var(--bg-secondary);color:var(--text-primary)}@media (max-width:768px){.plans-grid{grid-template-columns:1fr}.modal-overlay{padding:.5rem}.modal-content{padding:1.5rem}}.telegram-section{align-items:stretch;flex-direction:column;gap:1rem}.telegram-section .setting-info{margin-bottom:.5rem}.telegram-section .setting-controls{width:100%}.telegram-connected{align-items:center;background:linear-gradient(135deg,#10b9811a,#10b9810d);border:1px solid #10b9814d;border-radius:.75rem;display:flex;flex-wrap:wrap;gap:.75rem;padding:1rem 1.25rem}.telegram-connected .connected-icon{color:#10b981;flex-shrink:0}.telegram-connected .connected-info{display:flex;flex:1 1;flex-direction:column;gap:.25rem}.telegram-connected .connected-text{color:#10b981;font-size:.9375rem;font-weight:600}.telegram-connected .chat-id-display{background:#10b98126;border-radius:.25rem;color:var(--text-secondary);display:inline-block;font-family:SF Mono,Consolas,monospace;font-size:.8125rem;padding:.25rem .5rem}.telegram-connected .refresh-btn{background:#10b9811a;border:1px solid #10b9814d;border-radius:.5rem;color:#10b981;cursor:pointer;margin-left:auto;padding:.5rem;transition:all .2s}.telegram-connected .refresh-btn:hover:not(:disabled){background:#10b981;color:#fff}.telegram-not-connected{background:var(--bg-tertiary);border:1px dashed var(--border-color);border-radius:.75rem;display:flex;flex-direction:column;gap:1rem;padding:1rem}.telegram-not-connected .connect-prompt p{color:var(--text-secondary);font-size:.875rem;line-height:1.5;margin:0}.telegram-not-connected .connect-actions{display:flex;flex-wrap:wrap;gap:.75rem}.connect-telegram-btn{align-items:center;background:linear-gradient(135deg,#08c,#0077b5);border:none;border-radius:.625rem;box-shadow:0 2px 8px #0088cc40;color:#fff;cursor:pointer;display:inline-flex;font-size:.9375rem;font-weight:600;gap:.5rem;padding:.75rem 1.5rem;transition:all .25s ease}.connect-telegram-btn:hover:not(:disabled){background:linear-gradient(135deg,#09d,#08c);box-shadow:0 4px 16px #0088cc59;transform:translateY(-2px)}.connect-telegram-btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.connect-telegram-btn svg{flex-shrink:0}.telegram-connected .connected-actions{align-items:center;display:flex;gap:.5rem;margin-left:auto}.test-btn{align-items:center;background:#3b82f61a;border:1px solid #3b82f64d;border-radius:.5rem;color:#3b82f6;cursor:pointer;display:inline-flex;font-size:.8125rem;font-weight:500;gap:.375rem;padding:.5rem .875rem;transition:all .2s ease}.test-btn:hover:not(:disabled){background:#3b82f6;border-color:#3b82f6;color:#fff}.test-btn:disabled{cursor:not-allowed;opacity:.5}.test-btn svg{flex-shrink:0}.unbind-btn{align-items:center;background:#ef44441a;border:1px solid #ef44444d;border-radius:.5rem;color:#ef4444;cursor:pointer;display:inline-flex;font-size:.8125rem;font-weight:500;gap:.375rem;padding:.5rem .875rem;transition:all .2s ease}.unbind-btn:hover:not(:disabled){background:#ef4444;border-color:#ef4444;color:#fff}.unbind-btn:disabled{cursor:not-allowed;opacity:.5}.unbind-btn svg{flex-shrink:0}@media (max-width:768px){.telegram-section{padding:1rem}.telegram-connected{align-items:flex-start;flex-direction:column;padding:.875rem 1rem}.telegram-connected .connected-info{width:100%}.telegram-connected .connected-actions{justify-content:flex-start;margin-left:0;margin-top:.75rem;width:100%}.telegram-connected .refresh-btn{margin-left:0}.unbind-btn{flex:1 1;justify-content:center}.connect-telegram-btn{justify-content:center;width:100%}}.auth-page{align-items:center;background:var(--bg-primary);display:flex;justify-content:center;min-height:100vh;padding:2rem}.auth-container{background:var(--card-bg);border:1px solid var(--card-border);border-radius:24px;box-shadow:0 20px 60px #0000004d;display:grid;grid-template-columns:1fr 1fr;max-width:1200px;min-height:700px;overflow:hidden;width:100%}.auth-brand-side{background:linear-gradient(135deg,#667eea,#764ba2);display:flex;flex-direction:column;justify-content:center;overflow:hidden;padding:4rem;position:relative}.brand-content{position:relative;z-index:2}.brand-logo{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff3;border-radius:20px;box-shadow:0 8px 32px #0000001a;color:#fff;display:flex;height:80px;justify-content:center;margin-bottom:2rem;width:80px}.brand-title{color:#fff;font-size:3rem;font-weight:900;line-height:1.2;margin:0 0 1rem}.brand-tagline{color:#ffffffe6;font-size:1.25rem;line-height:1.6;margin:0 0 3rem}.brand-features{display:flex;flex-direction:column;gap:2.5rem;margin-top:1rem}.brand-feature{align-items:flex-start;display:flex;gap:1.5rem}.feature-icon{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff26;border-radius:14px;color:#fff;flex-shrink:0;height:56px;min-width:56px;width:56px}.feature-text{flex:1 1;min-width:0}.feature-text h3{color:#fff;font-size:1.125rem;font-weight:700;line-height:1.3;margin:0 0 .5rem}.feature-text p{color:#ffffffd9;font-size:.95rem;line-height:1.6;margin:0}.brand-decoration{bottom:0;left:0;pointer-events:none;position:absolute;right:0;top:0;z-index:1}.decoration-circle{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#ffffff1a;border-radius:50%;position:absolute}.circle-1{height:300px;right:-100px;top:-100px;width:300px}.circle-2{bottom:-50px;height:200px;left:-50px;width:200px}.circle-3{height:150px;opacity:.5;right:10%;top:50%;width:150px}.auth-form-side{align-items:center;background:var(--card-bg);display:flex;justify-content:center;padding:4rem}.auth-form-container{max-width:420px;width:100%}.auth-header{margin-bottom:2.5rem}.auth-header h2{color:var(--text-primary);font-size:2rem;font-weight:800;margin:0 0 .75rem}.auth-header p{color:var(--text-secondary);font-size:1.05rem;line-height:1.6;margin:0}.auth-error{align-items:center;animation:slideDown .3s ease-out;background:#ef44441a;border:1px solid var(--error-color);border-radius:12px;color:var(--error-color);display:flex;font-size:.95rem;gap:.75rem;margin-bottom:1.5rem;padding:1rem 1.25rem}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.auth-form{gap:1.5rem}.auth-form,.form-group{display:flex;flex-direction:column}.form-group{gap:.5rem}.form-group label{color:var(--text-primary);font-size:.95rem;font-weight:600}.input-wrapper{gap:.75rem}.input-icon-box,.input-wrapper{align-items:center;display:flex}.input-icon-box{background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:12px;color:var(--text-tertiary);height:48px;justify-content:center;min-width:48px;transition:all .3s;width:48px}.input-wrapper:focus-within .input-icon-box{background:#3b82f61a;border-color:var(--primary-color);color:var(--primary-color)}.input-field-wrapper{align-items:center;display:flex;flex:1 1;position:relative}.input-wrapper input{background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:12px;color:var(--text-primary);flex:1 1;font-size:1rem;padding:1rem 1.25rem;transition:all .3s;width:100%}.input-field-wrapper input{padding-right:3rem}.input-wrapper input:focus{background:var(--card-bg);border-color:var(--primary-color);box-shadow:0 0 0 4px #3b82f61a;outline:none}.input-wrapper input::placeholder,.password-toggle{color:var(--text-tertiary)}.password-toggle{align-items:center;background:none;border:none;cursor:pointer;display:flex;justify-content:center;padding:.5rem;position:absolute;right:1rem;transition:color .2s}.password-toggle:hover{color:var(--text-primary)}.auth-submit-btn{align-items:center;background:var(--gradient-primary);border:none;border-radius:12px;box-shadow:0 4px 12px #3b82f64d;color:#fff;cursor:pointer;display:flex;font-size:1.05rem;font-weight:700;gap:.75rem;justify-content:center;margin-top:.5rem;padding:1rem 1.5rem;transition:all .3s;width:100%}.auth-submit-btn:hover:not(:disabled){box-shadow:0 6px 20px #3b82f666;transform:translateY(-2px)}.auth-submit-btn:active:not(:disabled){transform:translateY(0)}.auth-submit-btn:disabled{cursor:not-allowed;opacity:.7}.spinner{animation:spin .6s linear infinite;border:2px solid #ffffff4d;border-top-color:#fff;height:18px;width:18px}.auth-footer{margin-top:2rem;text-align:center}.auth-footer p{color:var(--text-secondary);font-size:.95rem;margin:0}.auth-link{color:var(--primary-color);font-weight:600;text-decoration:none;transition:color .2s}.auth-link:hover{color:var(--primary-hover);text-decoration:underline}.modal-overlay{align-items:center;animation:fadeIn .2s;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;bottom:0;display:flex;justify-content:center;left:0;padding:2rem;position:fixed;right:0;top:0;z-index:1000}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modern-modal{animation:slideUp .3s ease-out;background:var(--card-bg);border:1px solid var(--card-border);border-radius:24px;box-shadow:0 20px 60px #0000004d;max-width:500px;position:relative;width:100%}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-close{align-items:center;background:var(--bg-secondary);border:none;border-radius:10px;color:var(--text-secondary);cursor:pointer;display:flex;height:36px;justify-content:center;position:absolute;right:1.5rem;top:1.5rem;transition:all .2s;width:36px;z-index:10}.modal-close:hover{background:var(--bg-hover);color:var(--text-primary)}.modal-icon-wrapper{display:flex;justify-content:center;padding:3rem 2rem 1rem}.modal-icon-wrapper svg{color:var(--primary-color)}.modal-body{padding:0 2.5rem 2rem;text-align:center}.modal-body h2{color:var(--text-primary);font-size:1.75rem;font-weight:800;margin:0 0 1rem}.modal-subtitle{color:var(--text-secondary);font-size:1.05rem;line-height:1.6;margin:0 0 2rem}.verification-steps{display:flex;flex-direction:column;gap:1rem;text-align:left}.verification-step{align-items:flex-start;display:flex;gap:1rem}.step-number{align-items:center;background:var(--gradient-primary);border-radius:10px;color:#fff;display:flex;flex-shrink:0;font-weight:700;height:32px;justify-content:center;width:32px}.step-text{color:var(--text-secondary);flex:1 1;font-size:.95rem;line-height:1.6;padding-top:.375rem}.modal-footer{padding:0 2.5rem 2.5rem}.modal-btn-primary{background:var(--gradient-primary);border:none;border-radius:12px;box-shadow:0 4px 12px #3b82f64d;color:#fff;cursor:pointer;font-size:1.05rem;font-weight:700;padding:1rem 1.5rem;transition:all .3s;width:100%}.modal-btn-primary:hover{box-shadow:0 6px 20px #3b82f666;transform:translateY(-2px)}@media (max-width:1024px){.auth-container{grid-template-columns:1fr;max-width:500px}.auth-brand-side{display:none}.auth-form-side{padding:3rem 2rem}}@media (max-width:768px){.auth-page{padding:1rem}.auth-form-side{padding:2rem 1.5rem}.auth-header h2{font-size:1.75rem}.modal-body,.modal-footer{padding:0 1.5rem 1.5rem}}.verify-email-container{align-items:center;display:flex;justify-content:center;min-height:calc(100vh - 200px);padding:2rem}.verify-email-card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:12px;box-shadow:0 4px 6px var(--card-shadow-md);max-width:500px;padding:3rem;text-align:center;width:100%}.verify-email-spinner{margin-bottom:2rem}.spinner{animation:spin 1s linear infinite;border-top:4px solid var(--border-color);border:4px solid var(--border-color);border-radius:50%;border-top-color:var(--primary-color);height:50px;margin:0 auto;width:50px}.verify-email-success-icon{background:var(--success-color)}.verify-email-error-icon,.verify-email-success-icon{align-items:center;animation:scaleIn .3s ease-out;border-radius:50%;color:var(--text-inverse);display:flex;font-size:3rem;font-weight:700;height:80px;justify-content:center;margin:0 auto 1.5rem;width:80px}.verify-email-error-icon{background:var(--error-color)}@keyframes scaleIn{0%{opacity:0;transform:scale(0)}to{opacity:1;transform:scale(1)}}.verify-email-card h2{color:var(--text-primary);font-size:1.5rem;margin:1rem 0}.verify-email-card p{color:var(--text-secondary);line-height:1.6;margin:.5rem 0}.verify-email-redirect{color:var(--text-tertiary);font-size:.9rem;font-style:italic}.verify-email-actions{display:flex;gap:1rem;justify-content:center;margin-top:2rem}.verify-email-actions .btn{border:none;border-radius:6px;cursor:pointer;font-size:1rem;padding:.75rem 1.5rem;transition:all .3s ease}.verify-email-actions .btn-primary{background:var(--primary-color);color:var(--text-inverse)}.verify-email-actions .btn-primary:hover{background:var(--primary-hover);box-shadow:0 4px 8px var(--card-shadow-md);transform:translateY(-2px)}.verify-email-actions .btn-secondary{background:var(--text-tertiary);color:var(--text-inverse)}.verify-email-actions .btn-secondary:hover{background:var(--text-secondary);box-shadow:0 4px 8px var(--card-shadow-md);transform:translateY(-2px)}.verify-email-required-page{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:2rem}.verify-email-required-container{background:#fff;background:var(--bg-card,#fff);border-radius:20px;box-shadow:0 25px 50px -12px #00000040;max-width:500px;padding:3rem;text-align:center;width:100%}.verify-icon-wrapper{align-items:center;border-radius:50%;display:flex;height:120px;justify-content:center;margin:0 auto 2rem;width:120px}.verify-icon-wrapper.warning{background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#fff}.verify-email-required-container h1{color:#1f2937;color:var(--text-primary,#1f2937);font-size:1.75rem;font-weight:700;margin:0 0 1rem}.verify-description{color:#6b7280;color:var(--text-secondary,#6b7280);font-size:1rem;line-height:1.6;margin:0 0 1.5rem}.email-display{background:#f3f4f6;background:var(--bg-secondary,#f3f4f6);border-radius:8px;display:inline-block;margin-bottom:1.5rem;padding:.75rem 1.5rem}.email-display span{color:#667eea;color:var(--primary-color,#667eea);font-weight:600}.verify-message{align-items:center;border-radius:10px;display:flex;font-weight:500;gap:.5rem;justify-content:center;margin-bottom:1.5rem;padding:1rem}.verify-message.success{background:#ecfdf5;border:1px solid #a7f3d0;color:#047857}.verify-message.error{background:#fef2f2;border:1px solid #fecaca;color:#b91c1c}.verify-message.info{background:#eff6ff;border:1px solid #bfdbfe;color:#1d4ed8}.verify-actions{display:flex;flex-direction:column;gap:.75rem;margin-bottom:2rem}.verify-actions button{align-items:center;border-radius:10px;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:.5rem;justify-content:center;padding:.875rem 1.5rem;transition:all .2s ease}.verify-actions button:disabled{cursor:not-allowed;opacity:.6}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);border:none}.btn-primary:hover:not(:disabled){box-shadow:0 8px 20px #667eea66;transform:translateY(-2px)}.btn-secondary{background:#f3f4f6;background:var(--bg-secondary,#f3f4f6);border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);color:#1f2937;color:var(--text-primary,#1f2937)}.btn-secondary:hover:not(:disabled){background:#e5e7eb;background:var(--bg-hover,#e5e7eb)}.btn-outline{background:#0000;border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);color:#6b7280;color:var(--text-secondary,#6b7280)}.btn-outline:hover:not(:disabled){border-color:#6b7280;border-color:var(--text-secondary,#6b7280);color:#1f2937;color:var(--text-primary,#1f2937)}.verify-tips{background:#f9fafb;background:var(--bg-secondary,#f9fafb);border-radius:12px;padding:1.5rem;text-align:left}.verify-tips h3{color:#1f2937;color:var(--text-primary,#1f2937);font-size:.9rem;font-weight:600;margin:0 0 .75rem}.verify-tips ul{margin:0;padding-left:1.25rem}.verify-tips li{color:#6b7280;color:var(--text-secondary,#6b7280);font-size:.85rem;margin-bottom:.35rem}.spin{animation:spin 1s linear infinite}@media (max-width:480px){.verify-email-required-container{padding:2rem}.verify-icon-wrapper{height:100px;width:100px}.verify-icon-wrapper svg{height:48px;width:48px}.verify-email-required-container h1{font-size:1.5rem}}.payment-result-page{align-items:center;background:var(--bg-primary);display:flex;justify-content:center;min-height:100vh;padding:2rem}.payment-result-container{background:var(--card-bg);border:1px solid var(--card-border);border-radius:24px;box-shadow:0 8px 32px var(--card-shadow);max-width:500px;padding:3rem;text-align:center;width:100%}.payment-icon{display:block;margin:0 auto 1.5rem}.payment-icon.processing{animation:spin 1s linear infinite;color:var(--info-color)}.payment-icon.success{color:var(--success-color)}.payment-icon.error{color:var(--error-color)}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.payment-result-container h1{color:var(--text-primary);font-size:2rem;font-weight:700;margin:0 0 1rem}.payment-result-container p{color:var(--text-secondary);font-size:1.125rem;line-height:1.6;margin:0 0 1rem}.redirect-message{color:var(--text-tertiary);font-size:.875rem;margin-top:1rem}.payment-actions{display:flex;gap:1rem;justify-content:center;margin-top:2rem}.btn-primary,.btn-secondary{border:none;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem 1.5rem;transition:all .2s ease}.btn-primary{background:var(--primary-color);color:#fff}.btn-primary:hover{background:var(--primary-hover);transform:translateY(-2px)}.btn-secondary{background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-primary)}.btn-secondary:hover{background:var(--bg-tertiary);border-color:var(--border-color-dark)}.error-page{align-items:center;background:var(--gradient-primary);display:flex;justify-content:center;min-height:100vh;padding:2rem}.error-container{animation:errorFadeIn .5s ease-in;background:var(--card-bg);border-radius:16px;box-shadow:0 20px 60px var(--card-shadow-hover);max-width:600px;padding:3rem;text-align:center;width:100%}@keyframes errorFadeIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.error-icon{animation:errorIconPulse 2s ease-in-out infinite;color:var(--primary-color)}@keyframes errorIconPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.1)}}.error-code{-webkit-text-fill-color:#0000;background:var(--gradient-primary);-webkit-background-clip:text;background-clip:text;font-size:6rem;font-weight:900;line-height:1;margin:0}.error-title{font-size:2rem;margin:1rem 0 .5rem}.error-message{font-size:1.1rem;margin:1.5rem 0 2rem}.error-actions{flex-wrap:wrap}.error-actions .btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:inline-flex;font-size:1rem;font-weight:600;padding:.75rem 1.5rem;text-decoration:none;transition:all .3s ease}.error-actions .btn-primary{background:var(--gradient-primary);color:var(--text-inverse)}.error-actions .btn-primary:hover{box-shadow:0 10px 20px var(--card-shadow-hover);transform:translateY(-2px)}.error-actions .btn-secondary{background:var(--bg-tertiary);color:var(--text-secondary)}.error-actions .btn-secondary:hover{background:var(--bg-hover);transform:translateY(-2px)}@media (max-width:768px){.error-container{padding:2rem 1.5rem}.error-code{font-size:4rem}.error-title{font-size:1.5rem}.error-message{font-size:1rem}.error-actions{flex-direction:column}.error-actions .btn{justify-content:center;width:100%}}:root{--bg-primary:#fff;--bg-secondary:#f8fafc;--bg-tertiary:#f1f5f9;--bg-hover:#f1f5f9;--text-primary:#1e293b;--text-secondary:#64748b;--text-tertiary:#94a3b8;--text-inverse:#fff;--border-color:#e2e8f0;--border-color-light:#f1f5f9;--border-color-dark:#cbd5e1;--card-bg:#fff;--card-bg-hover:#f8fafc;--card-border:#e2e8f0;--card-shadow:#0000000d;--card-shadow-hover:#0000001a;--card-shadow-sm:#0000000d;--card-shadow-md:#0000001a;--card-shadow-lg:#00000026;--overlay-dark:#0009;--primary-color:#667eea;--primary-hover:#5568d3;--primary-light:#e0e7ff;--secondary-color:#764ba2;--secondary-hover:#653a8a;--secondary-light:#f3e8ff;--accent-color:#f093fb;--accent-hover:#e879f9;--success-color:#10b981;--success-hover:#059669;--success-light:#d1fae5;--error-color:#ef4444;--error-hover:#dc2626;--error-light:#fee2e2;--warning-color:#f59e0b;--warning-hover:#d97706;--warning-light:#fef3c7;--warning-dark:#d97706;--info-color:#3b82f6;--info-hover:#2563eb;--info-light:#dbeafe;--info-dark:#2563eb;--navbar-bg:#fff;--navbar-border:#e2e8f0;--navbar-text:#1e293b;--navbar-hover:#f8fafc;--skeleton-bg:#e8e8e8;--skeleton-shine:#f0f0f0;--gradient-primary:linear-gradient(135deg,#667eea,#764ba2 50%,#f093fb);--gradient-secondary:linear-gradient(135deg,#f8fafc,#fff 50%,#f1f5f9);--gradient-dark:linear-gradient(135deg,#0f172a,#1e293b 50%,#334155);--header-bg:var(--card-bg);--icon-wrapper-bg:var(--primary-color);--button-primary-bg:var(--primary-color);--button-primary-hover-bg:var(--primary-hover);--text-shadow-light:#0003;--text-shadow-dark:#0000004d;--text-inverse-alpha-02:#fff3;--text-inverse-alpha-05:#ffffff80;--text-inverse-alpha-08:#fffc;--bg-glass-light:#ffffff1a;--bg-glass-light-hover:#fff3;--border-glass-light:#fff3;--border-glass-light-hover:#ffffff4d;--primary-color-alpha-01:#667eea1a;--primary-shadow-md:#667eea1f;--primary-shadow-hover:#667eea4d;--info-color-alpha-005:#3b82f60d;--info-color-alpha-008:#3b82f614;--info-color-alpha-01:#3b82f61a;--info-color-alpha-015:#3b82f626;--info-color-alpha-02:#3b82f633;--success-color-alpha-01:#10b9811a;--error-color-alpha-01:#ef44441a;--warning-color-alpha-015:#f59e0b26}[data-theme=dark]{--bg-primary:#0f172a;--bg-secondary:#1e293b;--bg-tertiary:#334155;--bg-hover:#1e293b;--text-primary:#f1f5f9;--text-primary-dark:#1e293b;--text-secondary:#cbd5e1;--text-tertiary:#94a3b8;--text-inverse:#0f172a;--border-color:#334155;--border-color-light:#1e293b;--border-color-dark:#475569;--card-bg:#1e293b;--card-bg-hover:#334155;--card-border:#334155;--card-shadow:#0000004d;--card-shadow-hover:#00000080;--card-shadow-sm:#0003;--card-shadow-md:#0006;--card-shadow-lg:#0009;--overlay-dark:#000000b3;--primary-color:#818cf8;--primary-hover:#6366f1;--primary-light:#312e81;--secondary-color:#a78bfa;--secondary-hover:#8b5cf6;--secondary-light:#4c1d95;--accent-color:#f472b6;--accent-hover:#ec4899;--success-color:#34d399;--success-hover:#10b981;--success-light:#064e3b;--error-color:#f87171;--error-hover:#ef4444;--error-light:#7f1d1d;--warning-color:#fbbf24;--warning-hover:#f59e0b;--warning-light:#78350f;--warning-dark:#f59e0b;--info-color:#60a5fa;--info-hover:#3b82f6;--info-light:#1e3a8a;--info-dark:#3b82f6;--navbar-bg:#1e293b;--navbar-border:#334155;--navbar-text:#f1f5f9;--navbar-hover:#334155;--skeleton-bg:#e0e0e0;--skeleton-shine:#f0f0f0;--gradient-primary:linear-gradient(135deg,#4c1d95,#5b21b6 50%,#7c3aed);--gradient-secondary:linear-gradient(135deg,#1e293b,#334155 50%,#475569);--gradient-dark:linear-gradient(135deg,#0f172a,#1e293b 50%,#334155);--header-bg:var(--card-bg);--icon-wrapper-bg:var(--primary-color);--button-primary-bg:var(--primary-color);--button-primary-hover-bg:var(--primary-hover);--text-shadow-light:#0000004d;--text-shadow-dark:#00000080;--text-inverse-alpha-02:#f1f5f933;--text-inverse-alpha-025:#f1f5f940;--text-inverse-alpha-03:#f1f5f94d;--text-inverse-alpha-05:#f1f5f980;--text-inverse-alpha-08:#f1f5f9cc;--bg-glass-light:#f1f5f91a;--bg-glass-light-hover:#f1f5f933;--border-glass-light:#f1f5f933;--border-glass-light-hover:#f1f5f94d;--primary-color-alpha-01:#818cf81a;--primary-color-alpha-015:#818cf826;--primary-shadow-md:#818cf81f;--primary-shadow-hover:#818cf84d;--info-color-alpha-005:#60a5fa0d;--info-color-alpha-008:#60a5fa14;--info-color-alpha-01:#60a5fa1a;--info-color-alpha-015:#60a5fa26;--info-color-alpha-02:#60a5fa33;--success-color-alpha-01:#34d3991a;--error-color-alpha-01:#f871711a;--warning-color-alpha-015:#fbbf2426;--secondary-color-alpha-015:#a78bfa26;--success-color-alpha-015:#34d39926;--success-color-alpha-02:#34d39933;--error-color-alpha-015:#f8717126;--error-color-alpha-02:#f8717133;--text-tertiary-alpha-015:#94a3b826;--text-tertiary-alpha-02:#94a3b833}*{transition:background-color .3s ease,color .3s ease,border-color .3s ease}button,img,input,select,svg,textarea{transition:background-color .3s ease,border-color .3s ease}.App{color:var(--text-primary);display:flex;flex-direction:column;min-height:100vh}.App,.main-content{background:var(--bg-primary)}.main-content{flex:1 1;margin:0;overflow-x:hidden;padding-left:0;padding-right:0;padding-top:80px;width:100%}.main-content>.technical-dashboard-new{margin-left:0;margin-right:0;margin-top:-80px;max-width:100vw;padding-top:0;width:100vw}.main-content>*{max-width:100%;width:100%}.hero{background:var(--gradient-primary);color:var(--text-inverse);padding:clamp(2rem,5vw,4rem) 0;text-align:center}.hero h1{font-size:clamp(1.75rem,5vw,3rem);font-weight:700;line-height:1.2;margin-bottom:1rem}.hero p{font-size:clamp(1rem,2.5vw,1.25rem);margin-bottom:2rem;margin-left:auto;margin-right:auto;max-width:min(600px,90vw);opacity:.9}.hero-buttons{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}.features{background:var(--bg-primary);padding:4rem 0}.features-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-top:3rem}.feature-card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:1rem;padding:2rem;text-align:center;transition:transform .2s ease,box-shadow .2s ease}.feature-card:hover{background:var(--card-bg-hover);box-shadow:0 10px 25px var(--card-shadow-hover);transform:translateY(-4px)}.feature-icon{align-items:center;background:var(--gradient-primary);border-radius:50%;color:var(--text-inverse);display:flex;height:64px;justify-content:center;margin:0 auto 1rem;width:64px}.feature-card h3{color:var(--text-primary);font-size:1.5rem;font-weight:600;margin-bottom:1rem}.feature-card p{color:var(--text-secondary);line-height:1.6}.stats{background:var(--gradient-dark);color:var(--text-inverse);padding:3rem 0}.stats-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));text-align:center}.stat-item h3{color:var(--info-color);font-size:2.5rem;font-weight:700;margin-bottom:.5rem}.stat-item p{color:var(--text-tertiary);font-size:1.1rem}@media (max-width:1024px){.features-grid{gap:clamp(1rem,2vw,2rem);grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.stats-grid{gap:clamp(1rem,2vw,2rem);grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}}@media (max-width:768px){.hero{padding:clamp(2rem,4vw,3rem) 0}.hero-buttons{align-items:center;flex-direction:column;gap:clamp(.5rem,2vw,1rem)}.features{padding:clamp(2rem,4vw,4rem) 0}.features-grid{gap:clamp(1rem,2vw,1.5rem);grid-template-columns:1fr}.stats{padding:clamp(2rem,4vw,3rem) 0}.stats-grid{gap:clamp(1rem,2vw,1.5rem);grid-template-columns:repeat(2,1fr)}}@media (max-width:480px){.hero{padding:clamp(1.5rem,4vw,2rem) 0}.stats-grid{gap:clamp(.75rem,2vw,1rem);grid-template-columns:1fr}.feature-card{padding:clamp(1.5rem,4vw,2rem)}}.error-boundary-container{align-items:center;background-color:var(--bg-primary);color:var(--text-primary);display:flex;flex-direction:column;font-family:Inter,system-ui,sans-serif;justify-content:center;min-height:100vh;padding:2rem;text-align:center}.error-card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:16px;box-shadow:0 10px 40px var(--card-shadow-lg);max-width:500px;padding:3rem;width:100%}.error-icon-wrapper{align-items:center;background:var(--error-color-alpha-01);border-radius:50%;color:var(--error-color);display:flex;height:80px;justify-content:center;margin:0 auto 1.5rem;width:80px}.error-title{color:var(--text-primary);font-size:1.8rem;font-weight:700;margin-bottom:1rem}.error-message{color:var(--text-secondary);line-height:1.6;margin-bottom:2rem}.error-actions{display:flex;gap:1rem;justify-content:center}.btn-reload{background:var(--primary-color);border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:600;padding:.8rem 1.5rem;transition:background .2s}.btn-reload:hover{background:var(--primary-hover)}.btn-home{background:#0000;border:1px solid var(--border-color);border-radius:8px;color:var(--text-secondary);cursor:pointer;font-weight:600;padding:.8rem 1.5rem;text-decoration:none;transition:all .2s}.btn-home:hover{background:var(--bg-hover);border-color:var(--border-color-dark);color:var(--text-primary)}.error-boundary{align-items:center;background:var(--gradient-primary);display:flex;justify-content:center;min-height:100vh;padding:2rem}.error-boundary-content{background:var(--card-bg);border:1px solid var(--card-border);border-radius:16px;box-shadow:0 20px 60px var(--card-shadow-lg);max-width:600px;padding:3rem;text-align:center}.error-icon{animation:shake .5s;color:var(--error-color);margin-bottom:1.5rem}@keyframes shake{0%,to{transform:translateX(0)}25%{transform:translateX(-10px)}75%{transform:translateX(10px)}}.error-boundary-content h1{color:var(--text-primary);font-size:2rem;font-weight:700;margin-bottom:1rem}.error-boundary-content p{color:var(--text-secondary);font-size:1.1rem;line-height:1.6;margin-bottom:2rem}.error-boundary-actions{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}.error-button{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:.5rem;padding:.875rem 1.5rem;transition:all .2s ease}.error-button.primary{background:var(--gradient-primary);color:var(--text-inverse)}.error-button.primary:hover{box-shadow:0 10px 20px var(--primary-shadow-hover);transform:translateY(-2px)}.error-button.secondary{background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-primary)}.error-button.secondary:hover{background:var(--bg-hover);transform:translateY(-2px)}.error-details{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;margin-top:2rem;padding:1rem;text-align:left}.error-details summary{color:var(--text-primary);cursor:pointer;font-weight:600;margin-bottom:1rem}.error-details pre{background:var(--bg-tertiary);border-radius:4px;color:var(--success-color);font-size:.875rem;max-height:300px;overflow-x:auto;overflow-y:auto;padding:1rem}@media (max-width:768px){.error-boundary{padding:1rem}.error-boundary-content{padding:2rem 1.5rem}.error-boundary-content h1{font-size:1.5rem}.error-boundary-content p{font-size:1rem}.error-boundary-actions{flex-direction:column}.error-button{justify-content:center;width:100%}}
/*# sourceMappingURL=main.971c4ee9.css.map*/