body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}*{box-sizing:border-box}.auth-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:20px}.auth-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #fff3;border-radius:20px;box-shadow:0 20px 40px #0000001a;max-width:500px;padding:40px;width:100%}.auth-header{margin-bottom:30px;text-align:center}.auth-header h1{color:#667eea;font-size:2.5rem;font-weight:700;margin-bottom:10px}.auth-header h2{color:#333;font-size:1.8rem;font-weight:600;margin-bottom:10px}.auth-header p{color:#666;font-size:1rem;margin-bottom:0}.auth-form{display:flex;flex-direction:column;gap:20px}.form-row{grid-gap:15px;display:grid;gap:15px;grid-template-columns:1fr 1fr}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-weight:600}.form-group input{background:#fff;border:2px solid #e1e5e9;border-radius:10px;padding:12px 16px;transition:all .3s ease}.form-group input:focus{box-shadow:0 0 0 3px #667eea1a}.form-group input.error{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.form-group input:disabled{background:#f9fafb;opacity:.7}.field-error{color:#ef4444;font-size:.875rem;font-weight:500}.error-message{background:#fef2f2;border:1px solid #fecaca;border-radius:10px;color:#dc2626;font-size:.95rem;font-weight:500;padding:12px 16px;text-align:center}.auth-button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:10px;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:600;margin-top:10px;padding:14px 24px;transition:all .3s ease}.auth-button:hover:not(:disabled){box-shadow:0 10px 20px #667eea4d;transform:translateY(-2px)}.auth-button:disabled{box-shadow:none;cursor:not-allowed;opacity:.7;transform:none}.auth-footer{border-top:1px solid #e1e5e9;margin-top:30px;padding-top:20px;text-align:center}.auth-footer p{color:#666;margin:0}.auth-link{color:#667eea;font-weight:600;text-decoration:none;transition:color .3s ease}.auth-link:hover{color:#764ba2;text-decoration:underline}@media (max-width:768px){.auth-container{padding:10px}.auth-card{max-width:100%;padding:30px 20px}.form-row{gap:20px;grid-template-columns:1fr}.auth-header h1{font-size:2rem}.auth-header h2{font-size:1.5rem}}.landing{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;min-height:100vh}.landing-nav{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border-bottom:1px solid #fff3;display:flex;justify-content:space-between;padding:1rem 2rem}.nav-brand h1{color:#fff;font-size:1.8rem}.nav-actions{align-items:center;display:flex;gap:1rem}.nav-link{border-radius:8px;color:#fff;font-weight:500;padding:.5rem 1rem;text-decoration:none;transition:all .3s ease}.nav-link:hover{background:#ffffff1a}.nav-button{background:#fff3;border:1px solid #ffffff4d;border-radius:10px;color:#fff;font-weight:600;padding:.75rem 1.5rem;text-decoration:none;transition:all .3s ease}.nav-button:hover{background:#ffffff4d;transform:translateY(-1px)}.landing-content{padding:0 2rem}.hero{margin:0 auto;max-width:1200px;padding:4rem 0;text-align:center}.hero-title{font-size:3.5rem;font-weight:700;line-height:1.2;margin-bottom:1.5rem}.gradient-text{-webkit-text-fill-color:#0000;background:linear-gradient(45deg,gold,orange);-webkit-background-clip:text;background-clip:text}.hero-subtitle{font-size:1.3rem;line-height:1.6;margin-bottom:2.5rem;margin-left:auto;margin-right:auto;max-width:700px;opacity:.9}.hero-actions{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}.cta-button{border:2px solid #0000;border-radius:12px;display:inline-block;font-size:1.1rem;font-weight:600;padding:1rem 2rem;text-decoration:none;transition:all .3s ease}.cta-button.primary{background:linear-gradient(45deg,gold,orange);color:#333}.cta-button.primary:hover{box-shadow:0 10px 25px #ffd7004d;transform:translateY(-2px)}.cta-button.secondary{background:#ffffff1a;border-color:#ffffff4d;color:#fff}.cta-button.secondary:hover{background:#fff3;transform:translateY(-2px)}.cta-button.large{font-size:1.2rem;padding:1.25rem 2.5rem}.features{margin:0 auto;max-width:1200px;padding:5rem 0}.features-header{margin-bottom:4rem;text-align:center}.features-header h2{font-size:2.5rem;font-weight:700;margin-bottom:1rem}.features-header p{font-size:1.2rem;opacity:.9}.features-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(350px,1fr))}.feature-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:20px;padding:2rem;transition:all .3s ease}.feature-card:hover{background:#ffffff26;box-shadow:0 20px 40px #0000001a;transform:translateY(-5px)}.feature-icon{display:block;font-size:3rem;margin-bottom:1rem}.feature-card h3{color:#fff;font-size:1.4rem;font-weight:600;margin-bottom:1rem}.feature-card p{line-height:1.6;opacity:.9}.tech-stack{margin:0 auto;max-width:1000px;padding:4rem 0}.tech-header{margin-bottom:3rem;text-align:center}.tech-header h2{font-size:2.2rem;font-weight:700;margin-bottom:1rem}.tech-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.tech-item{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:15px;line-height:1.6;padding:1.5rem}.tech-item strong{color:gold;font-weight:600}.cta-section{margin:0 auto;max-width:800px;padding:5rem 0;text-align:center}.cta-content h2{font-size:2.5rem;font-weight:700;margin-bottom:1rem}.cta-content p{font-size:1.2rem;margin-bottom:2rem;opacity:.9}.landing-footer{background:#0003;border-top:1px solid #fff3;padding:2rem}.footer-content{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1200px}.footer-brand h3{font-size:1.4rem;margin-bottom:.5rem}.footer-brand p,.footer-info p{margin:0;opacity:.8}@media (max-width:768px){.landing-nav{flex-direction:column;gap:1rem;padding:1rem}.nav-actions{justify-content:center;width:100%}.landing-content{padding:0 1rem}.hero{padding:2rem 0}.hero-title{font-size:2.5rem}.hero-subtitle{font-size:1.1rem}.hero-actions{align-items:center;flex-direction:column}.cta-button{max-width:300px;text-align:center;width:100%}.features-grid{gap:1.5rem}.features-grid,.tech-grid{grid-template-columns:1fr}.footer-content{flex-direction:column;gap:1rem;text-align:center}.cta-content h2,.features-header h2,.tech-header h2{font-size:2rem}}.page-container{background:#f7fafc;min-height:100vh;padding-bottom:40px}.page-content{margin:0 auto;max-width:1400px;padding:0 20px}.nav-header{background:#fff;box-shadow:0 2px 8px #0000001a;justify-content:space-between;margin-bottom:30px;padding:16px 20px}.nav-brand,.nav-header{align-items:center;display:flex}.nav-brand{cursor:pointer;gap:12px}.nav-brand h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;font-size:1.5rem;font-weight:700;margin:0}.nav-user{align-items:center;display:flex;gap:20px}.welcome-text{color:#4a5568;font-size:.95rem}.btn{transition:all .3s ease}.btn-secondary{background:#fff;border:2px solid #667eea;color:#667eea}.btn-secondary:hover{background:#667eea;color:#fff}.btn-danger{background:#ef5350;color:#fff}.btn-danger:hover{background:#e53935}.logout-button{background:#0000;border:2px solid #667eea;border-radius:8px;color:#667eea;cursor:pointer;font-size:.9rem;font-weight:500;padding:8px 16px;transition:all .3s ease}.logout-button:hover{background:#667eea;color:#fff}.btn-back{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;display:inline-flex;font-size:.9rem;font-weight:500;gap:6px;padding:8px 16px;transition:all .2s ease}.btn-back:hover{box-shadow:0 4px 12px #667eea4d;transform:translateY(-1px)}.card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:20px;transition:all .3s ease}.card-clickable{cursor:pointer}.card-clickable:hover{box-shadow:0 8px 24px #00000026;transform:translateY(-4px)}.card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.card-title{color:#2d3748;font-size:1.3rem;font-weight:600;margin:0}.loading-container{padding:60px 20px}.loading-spinner{border:4px solid #e2e8f0}.loading-text{color:#4a5568;font-size:.95rem;margin-top:16px}.error-message{background:#fff5f5;border:1px solid #fc8181;border-radius:8px;color:#c53030;margin:20px 0;padding:16px}.no-data-message{color:#718096;font-size:1.1rem;padding:60px 20px;text-align:center}.status-badge{font-size:.85rem;font-weight:500}.status-badge.success{background:#26a69a1a;color:#26a69a}.status-badge.error{background:#ef53501a;color:#ef5350}.status-badge.warning{background:#ffa7261a;color:#ffa726}.status-badge.info{background:#42a5f51a;color:#42a5f5}.market-change{align-items:center;display:inline-flex;font-weight:500;gap:4px}.market-change.positive{color:#26a69a}.market-change.negative{color:#ef5350}@media (max-width:768px){.page-content{padding:0 16px}.nav-header{flex-direction:column;gap:12px;padding:16px}.nav-user{justify-content:space-between;width:100%}.card{padding:16px}}.stats-bar{display:flex;flex-wrap:wrap;gap:20px;padding:20px 0}.stat-card{align-items:center;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;display:flex;flex:1 1;flex-direction:column;gap:8px;min-width:120px;padding:20px;transition:transform .2s ease}.stat-card:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.stat-value{align-items:center;color:#2d3748;display:flex;font-size:2rem;font-weight:700;gap:8px}.stat-icon{font-size:1.5rem}.stat-label{color:#718096;font-size:.9rem;font-weight:500;text-align:center}@media (max-width:768px){.stats-bar{gap:12px}.stat-card{min-width:100px;padding:16px}.stat-value{font-size:1.5rem}.stat-label{font-size:.8rem}}.dashboard{background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh}.dashboard-content{margin:0 auto;max-width:1200px;padding:2rem}.dashboard-header{color:#fff;margin-bottom:3rem;text-align:center}.dashboard-header h2{font-size:2.5rem;font-weight:700;margin-bottom:.5rem}.dashboard-subtitle{font-size:1.2rem;margin:0;opacity:.9}.dashboard-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-bottom:3rem}.dashboard-card{background:#fff;border:2px solid #0000;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:30px;text-align:center;transition:all .3s ease}.dashboard-card:hover{box-shadow:0 8px 24px #00000026;transform:translateY(-4px)}.dashboard-card.clickable{cursor:pointer}.dashboard-card.clickable:hover{border-color:#667eea}.card-icon{display:block;font-size:3rem;margin-bottom:1rem}.dashboard-card h3{color:#2d3748;font-size:1.4rem;font-weight:600;margin-bottom:.5rem}.dashboard-card p{color:#4a5568;line-height:1.6;margin-bottom:1rem}.card-status{background:#f5f5f5;border-radius:20px;color:#666;display:inline-block;font-size:.85rem;font-weight:500;margin-top:15px;padding:6px 16px}.card-status.active{background:linear-gradient(135deg,#e8f5e9,#c8e6c9);color:#2e7d32;font-weight:600}.phase-info{margin-top:3rem}.phase-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:15px;color:#fff;padding:2rem}.phase-card h3{color:#fff;font-size:1.5rem;font-weight:600;margin-bottom:1rem}.phase-card p{line-height:1.6;margin-bottom:1rem;opacity:.9}.phase-card ul{list-style:none;margin:1rem 0;padding:0}.phase-card li{opacity:.9;padding:.5rem 0}.phase-card strong{color:gold;font-weight:600}@media (max-width:768px){.dashboard-nav{flex-direction:column;gap:1rem;padding:1rem;text-align:center}.nav-brand h1{font-size:1.5rem}.dashboard-content{padding:1rem}.dashboard-header h2{font-size:2rem}.dashboard-grid{gap:1.5rem;grid-template-columns:1fr}.dashboard-card,.phase-card{padding:1.5rem}}.stock-list{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));margin-top:20px}.stock-list-empty{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:60px 20px;text-align:center}.empty-icon{font-size:4rem;margin-bottom:20px}.stock-list-empty h3{color:#333;font-size:1.5rem;margin:0 0 10px}.stock-list-empty p{color:#666;font-size:1rem;margin:0}.stock-card{background:#fff;border:2px solid #0000;border-radius:12px;box-shadow:0 2px 8px #0000001a;cursor:pointer;padding:20px;transition:all .3s ease}.stock-card:hover{border-color:#667eea;box-shadow:0 8px 24px #00000026;transform:translateY(-4px)}.stock-card-header{align-items:flex-start;border-bottom:2px solid #f0f0f0;display:flex;justify-content:space-between;margin-bottom:16px;padding-bottom:12px}.stock-info{flex:1 1}.stock-symbol{color:#333;font-size:1.5rem;font-weight:700;margin:0 0 4px}.stock-name{color:#666;font-size:.9rem;font-weight:400;margin:0}.stock-actions{display:flex;gap:8px}.action-btn{background:none;border:none;border-radius:4px;cursor:pointer;font-size:1.2rem;padding:4px 8px;transition:all .2s}.action-btn:hover{background-color:#f5f5f5;transform:scale(1.1)}.favorite-btn:hover{background-color:#fff3e0}.delete-btn:hover{background-color:#ffebee}.stock-card-body{margin-bottom:16px}.stock-detail{display:flex;font-size:.9rem;justify-content:space-between;padding:6px 0}.detail-label{color:#666;font-weight:500}.detail-value{color:#333;font-weight:400;text-align:right}.stock-card-footer{border-top:1px solid #f0f0f0;margin-top:16px;padding-top:12px}.stock-status{display:flex;gap:8px;margin-bottom:8px}.status-badge{border-radius:12px;display:inline-block;font-size:.75rem;font-weight:600;letter-spacing:.5px;padding:4px 12px;text-transform:uppercase}.status-badge.active{background-color:#e8f5e9;color:#2e7d32}.status-badge.inactive{background-color:#fafafa;color:#757575}.status-badge.fetched{background-color:#e3f2fd;color:#1565c0}.stock-dates{margin-top:8px}.stock-dates small{color:#999;font-size:.85rem}.stock-notes{background-color:#fff9c4;border-left:3px solid #fbc02d;border-radius:6px;margin-top:12px;padding:8px 12px}.stock-notes small{color:#f57f17;font-size:.85rem;line-height:1.4}@media (max-width:768px){.stock-list{grid-template-columns:1fr}.stock-card{padding:16px}.stock-symbol{font-size:1.3rem}}.modal-overlay{align-items:center;animation:fadeIn .2s ease-in-out;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{animation:slideUp .3s ease-out;background:#fff;border-radius:12px;box-shadow:0 10px 40px #0003;max-width:500px;padding:0;width:90%}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{align-items:center;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;padding:24px 24px 16px}.modal-header h2{color:#333;font-size:1.5rem;font-weight:600;margin:0}.modal-close{align-items:center;background:none;border:none;border-radius:4px;color:#999;cursor:pointer;display:flex;font-size:2rem;height:32px;justify-content:center;padding:0;transition:all .2s;width:32px}.modal-close:hover:not(:disabled){background-color:#f5f5f5;color:#333}.modal-close:disabled{cursor:not-allowed;opacity:.5}.modal-content form{padding:24px}.form-group label{color:#333;font-size:.95rem}.form-group input{border:2px solid #e0e0e0;border-radius:8px;box-sizing:border-box;font-size:1rem;padding:12px;transition:border-color .2s;width:100%}.form-group input:focus{border-color:#667eea;outline:none}.form-group input:disabled{background-color:#f5f5f5;cursor:not-allowed}.form-hint{color:#666;display:block;font-size:.85rem;margin-top:6px}.alert{font-size:.95rem;gap:10px;padding:12px 16px}.alert-icon{font-size:1.2rem}.alert-success{background-color:#e8f5e9;border:1px solid #a5d6a7;color:#2e7d32}.alert-info{background-color:#e3f2fd;border:1px solid #90caf9;color:#1565c0}.modal-footer{border-top:1px solid #e0e0e0;display:flex;gap:12px;justify-content:flex-end;margin-top:20px;padding-top:20px}.btn{padding:10px 24px}.btn-primary:hover:not(:disabled){box-shadow:0 4px 12px #667eea66;transform:translateY(-1px)}.btn-primary:disabled{cursor:not-allowed;opacity:.6;transform:none}.btn-secondary:hover:not(:disabled){background:#e0e0e0}.btn-secondary:disabled{cursor:not-allowed;opacity:.6}@media (max-width:600px){.modal-content{margin:20px;width:95%}.modal-header h2{font-size:1.25rem}}.stocks-page{background:#f7fafc;margin:0 auto;max-width:1400px;min-height:100vh;padding:20px}.header-content,.stocks-header{margin-bottom:30px}.header-content{align-items:center;display:flex;justify-content:space-between}.header-text h1{color:#2d3748;font-size:2rem;font-weight:700;margin:0 0 8px}.header-text p{color:#4a5568;font-size:1rem;margin:0}.btn{align-items:center;display:inline-flex;font-size:1rem;font-weight:600;gap:8px;padding:12px 24px}.btn-primary:hover{box-shadow:0 6px 20px #667eea66;transform:translateY(-2px)}.btn-icon{font-size:1.3rem;font-weight:700}.filter-bar{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;display:flex;gap:12px;padding:8px}.filter-btn{background:#0000;border:none;border-radius:8px;color:#666;cursor:pointer;flex:1 1;font-size:.95rem;font-weight:500;padding:10px 20px;transition:all .2s}.filter-btn:hover{background-color:#f5f5f5;color:#333}.filter-btn.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.loading-container{align-items:center;display:flex;flex-direction:column;gap:20px;justify-content:center;min-height:400px}.loading-container p{color:#666;font-size:1rem}.alert{align-items:center;border-radius:8px;display:flex;gap:12px;margin-bottom:20px;padding:16px 20px;position:relative}.alert-error{background-color:#ffebee;border:1px solid #ef9a9a;color:#c62828}.alert-icon{font-size:1.3rem}.alert-close{align-items:center;background:none;border:none;border-radius:4px;color:inherit;cursor:pointer;display:flex;font-size:1.5rem;height:24px;justify-content:center;padding:0;position:absolute;right:12px;top:50%;transform:translateY(-50%);transition:background-color .2s;width:24px}.alert-close:hover{background-color:#0000001a}@media (max-width:768px){.stocks-page{padding:15px}.header-content{align-items:flex-start;flex-direction:column;gap:15px}.header-text h1{font-size:1.5rem}.filter-bar{flex-direction:column}.filter-btn{text-align:center}}.indicator-panel{background:#fff;border:1px solid #e2e8f0;border-radius:8px;margin-top:24px;padding:24px}.indicator-panel-header{margin-bottom:24px}.indicator-panel-header h2{color:#2d3748;font-size:20px;font-weight:600;margin:0 0 8px}.indicator-panel-subtitle{color:#718096;font-size:14px;margin:0}.indicator-error-message{align-items:center;background-color:#fed7d7;border:1px solid #fc8181;border-radius:6px;color:#c53030;display:flex;font-size:14px;gap:12px;margin-bottom:16px;padding:12px 16px}.indicator-error-message .error-icon{flex-shrink:0;font-size:18px}.indicator-panel-content{background:#f7fafc;border:1px solid #edf2f7;border-radius:6px;margin-bottom:24px;padding:20px}.form-group{margin-bottom:20px}.form-group label{color:#2d3748;display:block;font-size:14px;font-weight:500;margin-bottom:8px}.form-group input,.form-group select,.indicator-select{background-color:#fff;border:1px solid #cbd5e0;border-radius:4px;color:#2d3748;font-size:14px;padding:10px 12px;transition:border-color .2s ease,box-shadow .2s ease;width:100%}.form-group input:focus,.form-group select:focus,.indicator-select:focus{border-color:#3182ce;box-shadow:0 0 0 3px #3182ce1a;outline:none}.form-group input:disabled,.form-group select:disabled,.indicator-select:disabled{background-color:#edf2f7;color:#a0aec0;cursor:not-allowed}.form-hint{color:#718096;font-size:12px;margin-bottom:0;margin-top:4px}.indicator-description{color:#4a5568;font-size:13px;font-style:italic;margin-bottom:0;margin-top:8px}.parameters-section{border-top:1px solid #e2e8f0;margin-bottom:20px;padding-top:16px}.parameters-section h3{color:#2d3748;font-size:14px;font-weight:600;margin:0 0 12px}.parameters-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.parameter-input{display:flex;flex-direction:column}.parameter-input label{color:#4a5568;font-size:13px;font-weight:500;margin-bottom:6px}.parameter-input-field{background-color:#fff;border:1px solid #cbd5e0;border-radius:4px;color:#2d3748;font-size:13px;padding:8px 10px;transition:border-color .2s ease}.parameter-input-field:focus{border-color:#3182ce;box-shadow:0 0 0 3px #3182ce1a;outline:none}.parameter-input-field:disabled{background-color:#edf2f7;color:#a0aec0;cursor:not-allowed}.indicator-name-input{width:100%}.calculate-section{border-top:1px solid #e2e8f0;margin-top:20px;padding-top:16px}.btn-calculate{background-color:#3182ce;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:15px;font-weight:600;padding:12px 20px;transition:background-color .2s ease,transform .1s ease;width:100%}.btn-calculate:hover:not(:disabled){background-color:#2c5282;transform:translateY(-1px)}.btn-calculate:active:not(:disabled){transform:translateY(0)}.btn-calculate:disabled{background-color:#cbd5e0;cursor:not-allowed}.progress-bar{background-color:#e2e8f0;border-radius:3px;height:6px;margin-top:12px;overflow:hidden}.progress-fill{background-color:#48bb78;border-radius:3px;height:100%;transition:width .3s ease}.indicators-list-section{margin-top:24px}.indicators-list-section h3{color:#2d3748;font-size:16px;font-weight:600;margin:0 0 16px}.indicators-list{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.indicator-item{background:#f7fafc;border:1px solid #e2e8f0;border-radius:6px;padding:16px;transition:border-color .2s ease,background-color .2s ease}.indicator-item:hover{background-color:#edf2f7;border-color:#cbd5e0}.indicator-item-header{align-items:baseline;display:flex;gap:8px;margin-bottom:8px}.indicator-item-header h4{color:#2d3748;font-size:14px;font-weight:600;margin:0}.indicator-function{color:#718096;font-size:12px;font-weight:400}.indicator-item-details{display:flex;flex-direction:column;gap:6px;margin-bottom:8px}.indicator-item-details p{color:#4a5568;font-size:12px;margin:0;word-break:break-word}.indicator-calculated-at{color:#718096;font-style:italic}.indicator-date-range{color:#4a5568}.indicator-parameters{background:#fff;border-left:3px solid #3182ce;border-radius:3px;color:#2d3748;font-family:Courier New,monospace;font-size:11px;padding:6px 8px}.indicator-item-data-preview{border-top:1px solid #cbd5e0;padding-top:8px}.data-points{color:#718096;font-size:12px;font-weight:500;margin:0}.loading-indicators,.no-indicators{background:#f7fafc;border-radius:6px;color:#718096;font-size:14px;padding:32px 16px;text-align:center}.loading-indicators p,.no-indicators p{margin:0}@media (max-width:768px){.indicator-panel,.indicator-panel-content{padding:16px}.parameters-grid{grid-template-columns:repeat(auto-fit,minmax(120px,1fr))}.indicators-list{grid-template-columns:1fr}}@media (max-width:480px){.indicator-panel{margin-top:16px;padding:12px}.indicator-panel-header h2{font-size:18px}.form-group label,.indicator-panel-subtitle{font-size:13px}.parameters-grid{grid-template-columns:1fr}.btn-calculate{font-size:14px;padding:10px 16px}}.indicator-chart{background:#fff;border:1px solid #e2e8f0;border-radius:8px;margin-top:16px;overflow:hidden}.indicator-chart-header{align-items:center;background:#f7fafc;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;padding:16px 24px}.indicator-chart-header h3{color:#2d3748;font-size:16px;font-weight:600;margin:0}.indicator-legend{display:flex;flex-wrap:wrap;gap:16px}.legend-item{font-size:13px}.legend-color{border-radius:2px;display:inline-block;flex-shrink:0;height:12px;width:12px}.legend-text{white-space:nowrap}.indicator-chart-container{min-height:300px;position:relative;width:100%}.indicator-chart-empty{align-items:center;background:#f7fafc;border:1px dashed #cbd5e0;border-radius:8px;color:#718096;display:flex;font-size:14px;justify-content:center;min-height:300px;padding:24px;text-align:center}.indicator-chart-empty p{margin:0}@media (max-width:768px){.indicator-chart-header{align-items:flex-start;flex-direction:column;gap:12px}.indicator-legend{gap:8px;width:100%}.legend-item{font-size:12px}}@media (max-width:480px){.indicator-chart-header{padding:12px 16px}.indicator-chart-header h3{font-size:14px}.indicator-legend{gap:6px}.legend-item{font-size:11px}}.stock-chart{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:20px;padding:20px}.stock-chart-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.stock-chart-header h3{color:#2d3748;font-size:1.3rem;font-weight:600;margin:0}.chart-legend{display:flex;gap:20px}.legend-item{align-items:center;color:#4a5568;display:flex;font-size:.9rem;gap:6px}.legend-dot{border-radius:2px;display:inline-block;height:12px;width:12px}.legend-dot.up{background-color:#26a69a}.legend-dot.down{background-color:#ef5350}.price-chart-container{margin-bottom:10px;min-height:350px;min-width:400px;width:100%}.volume-chart-header{color:#718096;font-size:.85rem;font-weight:500;margin-bottom:8px;padding-left:4px}.volume-chart-container{margin-top:4px;min-height:150px;min-width:400px;width:100%}@media (max-width:768px){.stock-chart{padding:15px}.stock-chart-header{align-items:flex-start;flex-direction:column;gap:10px}.chart-legend{gap:15px}}.stock-detail-page{background:#f7fafc;margin:0 auto;max-width:1400px;min-height:100vh;padding:20px}.stock-detail-header{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:30px;padding:24px}.back-btn{align-items:center;background:none;border:none;color:#667eea;cursor:pointer;display:inline-flex;font-size:1rem;font-weight:500;margin-bottom:20px;padding:8px 0;transition:all .2s}.back-btn:hover{color:#764ba2;transform:translateX(-4px)}.stock-title{margin-bottom:16px}.title-row{align-items:flex-start;display:flex;gap:16px;justify-content:space-between}.title-content{flex:1 1}.stock-title h1{color:#2d3748;font-size:2.5rem;font-weight:700;margin:0 0 8px}.stock-name-large{color:#4a5568;font-size:1.5rem;font-weight:500;margin:0}.favorite-btn-large{background:none;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;font-size:1.5rem;padding:8px 16px;transition:all .2s}.favorite-btn-large:hover{transform:scale(1.1)}.favorite-btn-large.active,.favorite-btn-large:hover{background-color:#fff9c4;border-color:#fbc02d}.stock-badges{display:flex;gap:12px}.badge{border-radius:20px;display:inline-block;font-size:.85rem;font-weight:600;letter-spacing:.5px;padding:6px 16px;text-transform:uppercase}.badge-success{background-color:#e8f5e9;color:#2e7d32}.badge-secondary{background-color:#fafafa;color:#757575}.badge-info{background-color:#e3f2fd;color:#1565c0}.info-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-bottom:30px}.info-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:24px}.info-card h3{border-bottom:2px solid #f0f0f0;color:#333;font-size:1.2rem;font-weight:600;margin:0 0 20px;padding-bottom:12px}.info-rows{display:flex;flex-direction:column;gap:12px}.info-row{align-items:center;display:flex;justify-content:space-between}.info-label{color:#666;font-size:.95rem;font-weight:500}.info-value{color:#333;font-size:.95rem;font-weight:400;text-align:right}.card-header-with-action{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.card-header-with-action h3{border:none;margin:0;padding:0}.btn-edit{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;display:inline-flex;font-size:.85rem;font-weight:500;gap:6px;padding:8px 16px;transition:all .2s ease}.btn-edit:hover{box-shadow:0 4px 12px #667eea4d;transform:translateY(-1px)}.btn-save{align-items:center;background:linear-gradient(135deg,#48bb78,#38a169);border:none;border-radius:8px;color:#fff;cursor:pointer;display:inline-flex;font-size:.85rem;font-weight:500;gap:6px;padding:8px 16px;transition:all .2s ease}.btn-save:hover{box-shadow:0 4px 12px #48bb784d;transform:translateY(-1px)}.btn-cancel{align-items:center;background:#f5f7fa;border:2px solid #e2e8f0;border-radius:8px;color:#4a5568;cursor:pointer;display:inline-flex;font-size:.85rem;font-weight:500;gap:6px;padding:8px 16px;transition:all .2s ease}.btn-cancel:hover{background:#e2e8f0;transform:translateY(-1px)}.notes-card{grid-column:1/-1}.notes-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.edit-btn{background:none;border:none;border-radius:6px;color:#667eea;cursor:pointer;font-size:.9rem;font-weight:500;padding:6px 12px;transition:all .2s}.edit-btn:hover{background-color:#f5f5f5}.notes-display{background:#f9fafb;border-radius:8px;color:#666;line-height:1.6;margin:0;min-height:60px;padding:12px;white-space:pre-wrap}.notes-input{border:2px solid #e2e8f0;border-radius:8px;box-sizing:border-box;font-family:inherit;font-size:.95rem;padding:12px;resize:vertical;transition:border-color .2s ease;width:100%}.notes-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.notes-edit textarea{border:2px solid #e0e0e0;border-radius:8px;box-sizing:border-box;font-family:inherit;font-size:.95rem;margin-bottom:12px;padding:12px;resize:vertical;width:100%}.notes-edit textarea:focus{border-color:#667eea;outline:none}.notes-actions{display:flex;gap:12px;justify-content:flex-end}.chart-controls{align-items:center;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:20px;padding:20px}.chart-type-selector,.time-range-selector{align-items:center;display:flex;gap:8px}.chart-type-btn,.time-btn{background:#f5f7fa;border:2px solid #e2e8f0;border-radius:8px;color:#4a5568;cursor:pointer;font-size:.9rem;font-weight:500;padding:10px 18px;transition:all .2s ease;white-space:nowrap}.chart-type-btn:hover,.time-btn:hover{background:#edf2f7;border-color:#cbd5e0;color:#2d3748;transform:translateY(-1px)}.chart-type-btn.active,.time-btn.active{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#0000;box-shadow:0 4px 12px #667eea4d;color:#fff}.refresh-btn{align-items:center;background:linear-gradient(135deg,#48bb78,#38a169);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:.9rem;font-weight:500;gap:6px;padding:10px 20px;transition:all .2s ease;white-space:nowrap}.refresh-btn:hover{background:linear-gradient(135deg,#38a169,#2f855a);box-shadow:0 4px 12px #48bb7866;transform:translateY(-1px)}.refresh-btn:active{transform:translateY(0)}.refresh-btn:disabled{cursor:not-allowed;opacity:.5}.control-group{align-items:center;display:flex;gap:12px}.control-group label{color:#666;font-size:.95rem;font-weight:500}.btn-group{display:flex;gap:8px}.btn-control{background:#f5f5f5;border:2px solid #0000;border-radius:8px;color:#666;cursor:pointer;font-size:.9rem;font-weight:500;padding:8px 16px;transition:all .2s}.btn-control:hover{background:#e0e0e0;color:#333}.btn-control.active{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#0000;color:#fff}.btn{border:none;border-radius:8px;cursor:pointer;font-size:.95rem;font-weight:500;padding:10px 20px;transition:all .2s}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-primary:hover{box-shadow:0 4px 12px #667eea66;transform:translateY(-1px)}.btn-secondary{background:#f5f5f5;color:#333}.btn-secondary:hover{background:#e0e0e0}.chart-loading,.no-data-message{align-items:center;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;display:flex;flex-direction:column;justify-content:center;min-height:400px}.chart-loading{gap:20px}.error-container,.loading-container{align-items:center;display:flex;flex-direction:column;gap:20px;justify-content:center;min-height:400px}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #f0f0f0;border-radius:50%;border-top-color:#667eea;height:50px;width:50px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.chart-loading p,.loading-container p,.no-data-message p{color:#666;font-size:1rem;margin:0}.error-container{text-align:center}.error-icon{font-size:3rem}.error-container h2{color:#333;margin:0 0 10px}.error-container p{color:#666;margin:0 0 20px}.indicators-section{margin-top:30px}.indicators-toggle{display:flex;justify-content:flex-start;margin-bottom:16px}.toggle-indicators-btn{align-items:center;background:#f5f7fa;border:2px solid #e2e8f0;border-radius:8px;color:#4a5568;cursor:pointer;display:flex;font-size:.9rem;font-weight:500;gap:6px;padding:10px 18px;transition:all .2s ease;white-space:nowrap}.toggle-indicators-btn:hover{background:#edf2f7;border-color:#cbd5e0;color:#2d3748;transform:translateY(-1px)}.toggle-indicators-btn.active{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#0000;box-shadow:0 4px 12px #667eea4d;color:#fff}@media (max-width:768px){.stock-detail-page{padding:15px}.stock-title h1{font-size:2rem}.info-grid{grid-template-columns:1fr}.chart-controls,.control-group{align-items:stretch;flex-direction:column}.btn-group{justify-content:space-between}}.App{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;min-height:100vh;text-align:center}.App-header{margin:0 auto;max-width:1200px;padding:40px 20px}.App h1{font-size:3.5rem;margin:0;text-shadow:2px 2px 4px #0000004d}.App-subtitle{font-size:1.2rem;margin:10px 0 40px;opacity:.9}.status-section{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:15px;margin:30px 0;padding:30px}.status-section h2{color:#fff;font-size:1.8rem;margin-top:0}.loading{font-size:1.1rem;padding:20px}.connection-status{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-top:20px}.status-card{background:#ffffff26;border:1px solid #fff3;border-radius:10px;padding:20px}.status-card h3{color:#fff;font-size:1.3rem;margin-top:0}.status.healthy{color:#4ade80}.status.error{color:#f87171}.info{text-align:left}.info p{font-size:.95rem;margin:8px 0}.features ul{margin:10px 0;padding-left:20px}.features li{font-size:.9rem;margin:5px 0}.next-steps{background:#ffffff1a;border:1px solid #fff3;border-radius:15px;margin:30px 0;padding:30px}.next-steps h3{color:#4ade80;font-size:1.5rem;margin-top:0}.links{display:flex;flex-wrap:wrap;gap:15px;justify-content:center;margin-top:20px}.link-button{background:#fff3;border:1px solid #ffffff4d;border-radius:8px;color:#fff;font-weight:500;padding:12px 24px;text-decoration:none;transition:all .3s ease}.link-button:hover{background:#ffffff4d;box-shadow:0 4px 12px #0003;transform:translateY(-2px)}.error{color:#f87171}
/*# sourceMappingURL=main.eb24dfce.css.map*/