.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.auth-box{background:#fff;border-radius:12px;padding:40px;box-shadow:0 20px 60px #0000004d;width:100%;max-width:400px}.auth-box-wide{max-width:600px}.auth-title{font-size:28px;font-weight:700;text-align:center;color:#1e293b;margin-bottom:8px}.auth-subtitle{font-size:16px;text-align:center;color:#64748b;margin-bottom:32px}.btn-block{width:100%;margin-top:8px}.auth-footer{text-align:center;margin-top:24px;color:#64748b;font-size:14px}.auth-footer a{color:#2563eb;text-decoration:none;font-weight:500}.auth-footer a:hover{text-decoration:underline}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}@media (max-width: 600px){.form-row{grid-template-columns:1fr}}.optimization-metrics-container{padding:2rem;max-width:1400px;margin:0 auto}.metrics-header{text-align:center;margin-bottom:2rem}.metrics-header h2{font-size:2rem;color:#333;margin-bottom:.5rem}.metrics-description{color:#666;font-size:1rem}.metrics-info-card{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:1.5rem;border-radius:12px;margin-bottom:2rem;box-shadow:0 4px 6px #0000001a}.info-row{display:flex;gap:2rem;margin-bottom:1rem}.info-row:last-child{margin-bottom:0}.info-item{flex:1;display:flex;flex-direction:column;gap:.25rem}.info-item.full-width{flex:100%}.info-label{font-size:.85rem;opacity:.9;font-weight:500}.info-value{font-size:1.1rem;font-weight:600}.metrics-comparison-section{margin-bottom:2rem}.metrics-comparison-section h3{font-size:1.5rem;color:#333;margin-bottom:.5rem}.metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin-top:1.5rem}.metric-card{background:#fff;border:2px solid #e0e0e0;border-radius:12px;padding:1.5rem;transition:all .3s ease}.metric-card:hover{border-color:#667eea;box-shadow:0 4px 12px #667eea26;transform:translateY(-2px)}.metric-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.metric-icon{font-size:1.5rem}.metric-title{font-size:.95rem;font-weight:600;color:#555}.metric-value{font-size:2rem;font-weight:700;color:#333;margin-bottom:.5rem}.metric-value.positive{color:#4caf50}.metric-value.negative{color:#f44336}.metric-label{font-size:.85rem;color:#666;font-weight:500}.metrics-note{background:#f8f9fa;border-left:4px solid #667eea;padding:1.5rem;border-radius:8px;margin-top:2rem}.metrics-note h4{font-size:1.1rem;color:#333;margin-bottom:1rem}.metrics-note ul{list-style:none;padding:0}.metrics-note li{margin-bottom:1rem;padding-left:1.5rem;position:relative;color:#555;line-height:1.6}.metrics-note li:before{content:"•";position:absolute;left:0;color:#667eea;font-weight:700;font-size:1.5rem;line-height:1.2}.metrics-note li strong{color:#333}.optimization-metrics-loading,.optimization-metrics-error,.optimization-metrics-empty{text-align:center;padding:3rem 2rem;color:#666}.optimization-metrics-empty h3{font-size:1.5rem;color:#333;margin-bottom:1rem}.optimization-metrics-empty p{color:#666;line-height:1.6}.optimization-metrics-empty ol{text-align:left;line-height:1.8}@media (max-width: 768px){.optimization-metrics-container{padding:1rem}.metrics-grid{grid-template-columns:1fr}.info-row{flex-direction:column;gap:1rem}.metric-value{font-size:1.5rem}}.regime-behavior-map{padding:1.5rem;background:#fff;border-radius:8px;max-width:1400px;margin:0 auto}.regime-map-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;gap:1rem}.regime-map-header h3{margin:0 0 .5rem;font-size:1.5rem;color:#1a1a1a}.regime-map-subtitle{margin:0;color:#666;font-size:.9rem}.recalculate-button{padding:.5rem 1rem;background:#2196f3;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;transition:background .2s;white-space:nowrap}.recalculate-button:hover:not(:disabled){background:#1976d2}.recalculate-button:disabled{background:#ccc;cursor:not-allowed}.regime-summary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:1rem 1.5rem;border-radius:8px;margin-bottom:2rem;display:flex;align-items:center;gap:1rem;box-shadow:0 2px 8px #667eea4d}.summary-icon{font-size:1.5rem}.regime-summary p{margin:0;font-size:1rem;line-height:1.5}.regime-cards-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:1.5rem;margin-bottom:2rem}.regime-card{border:1px solid #e0e0e0;border-radius:8px;overflow:hidden;background:#fff;transition:box-shadow .2s,transform .2s}.regime-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.regime-card-header{display:flex;align-items:center;gap:1rem;padding:1.25rem;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);border-bottom:1px solid #e0e0e0}.regime-icon{width:48px;height:48px;border-radius:8px;display:flex;align-items:center;justify-content:center}.regime-title h4{margin:0 0 .25rem;font-size:1.1rem;color:#1a1a1a}.regime-description{margin:0;font-size:.85rem;color:#666}.regime-card-body{padding:1.25rem}.regime-card-empty{padding:2rem 1.25rem;text-align:center;color:#999;font-style:italic}.rating-badge{display:inline-block;padding:.4rem 1rem;border-radius:20px;font-weight:600;font-size:.85rem;margin-bottom:1rem}.performance-section{margin-bottom:1rem}.performance-section label{display:block;font-size:.85rem;color:#666;margin-bottom:.5rem;font-weight:500}.performance-bar-container{display:flex;align-items:center;gap:1rem}.performance-bar-track{flex:1;height:32px;background:#f5f5f5;border-radius:16px;position:relative;overflow:hidden}.performance-bar-fill{height:100%;border-radius:16px;transition:width .5s ease,background-color .3s;display:flex;align-items:center;justify-content:flex-end;padding-right:.5rem}.performance-bar-zero{position:absolute;left:50%;top:0;bottom:0;width:2px;background:#999;transform:translate(-50%)}.performance-value{font-weight:700;font-size:1.1rem;min-width:60px;text-align:right}.comparison-section{padding:.75rem;background:#f9f9f9;border-radius:6px;margin-bottom:1rem}.comparison-row{display:flex;justify-content:space-between;align-items:center}.comparison-label{font-size:.9rem;color:#666}.comparison-value{font-weight:600;font-size:1rem}.metrics-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem;margin-bottom:1rem}.metric-item{display:flex;flex-direction:column;gap:.25rem}.metric-item label{font-size:.8rem;color:#666}.metric-item span{font-weight:600;font-size:1rem;color:#1a1a1a}.data-info{padding-top:.75rem;border-top:1px solid #e0e0e0;text-align:center}.data-info-text{font-size:.8rem;color:#999}.regime-legend{background:#f9f9f9;padding:1.25rem;border-radius:8px;border:1px solid #e0e0e0}.regime-legend h5{margin:0 0 1rem;font-size:1rem;color:#1a1a1a}.legend-items{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:.75rem}.legend-item{display:flex;align-items:center}.legend-badge{padding:.35rem .75rem;border-radius:16px;font-size:.8rem;font-weight:600}.legend-note{margin:0;font-size:.8rem;color:#666;font-style:italic}.regime-map-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;text-align:center}.loading-spinner{width:48px;height:48px;border:4px solid #f3f3f3;border-top:4px solid #2196f3;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}.regime-map-loading p{color:#666;font-size:1rem}.regime-map-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;text-align:center;color:#f44336}.regime-map-error p{margin:1rem 0;font-size:1rem}.retry-button{padding:.75rem 1.5rem;background:#2196f3;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:1rem;transition:background .2s}.retry-button:hover{background:#1976d2}.regime-map-empty{padding:3rem;text-align:center;color:#999}@media (max-width: 768px){.regime-behavior-map{padding:1rem}.regime-map-header{flex-direction:column;align-items:stretch}.recalculate-button{width:100%}.regime-cards-grid{grid-template-columns:1fr;gap:1rem}.metrics-grid{grid-template-columns:1fr}.performance-bar-container{flex-direction:column;align-items:stretch}.performance-value{text-align:center;min-width:auto}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{background:#fff;border-radius:8px;box-shadow:0 4px 6px #0000001a;width:100%;max-width:600px;max-height:90vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:flex-start;padding:1.5rem;border-bottom:1px solid #e0e0e0}.modal-header h2{margin:0;font-size:1.5rem;color:#333}.modal-close{background:none;border:none;font-size:2rem;line-height:1;color:#666;cursor:pointer;padding:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background-color .2s}.modal-close:hover{background-color:#f0f0f0;color:#333}.modal-body{padding:1.5rem}.modal-footer{padding:1.5rem;border-top:1px solid #e0e0e0;display:flex;justify-content:flex-end;gap:1rem}@media (max-width: 768px){.modal-content{max-width:100%;margin:0;border-radius:0;max-height:100vh}.modal-overlay{padding:0}}.yearly-metrics-container{margin-top:1rem;padding:1.5rem;background-color:#f8f9fa;border-radius:8px;border:1px solid #e0e0e0}.metrics-toggle{margin-top:1rem}.metrics-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid #dee2e6}.metrics-header h3{margin:0;color:#333;font-size:1.3rem}.metrics-section{margin-bottom:2rem}.metrics-section:last-of-type{margin-bottom:1rem}.metrics-section h4{margin-bottom:1rem;color:#555;font-size:1.1rem;font-weight:600}.metrics-table{width:100%;background-color:#fff;border-collapse:collapse;border-radius:4px;overflow:hidden;box-shadow:0 1px 3px #0000001a}.metrics-table thead{background-color:#495057;color:#fff}.metrics-table th,.metrics-table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid #dee2e6}.metrics-table th{font-weight:600;font-size:.9rem;text-transform:uppercase;letter-spacing:.5px}.metrics-table tbody tr:hover{background-color:#f8f9fa}.metrics-table tbody tr:last-child td{border-bottom:none}.loading-metrics,.error-metrics{padding:1rem;text-align:center;color:#666}.error-metrics{color:#f44336;background-color:#ffebee;border-radius:4px}.metrics-legend{margin-top:1.5rem;padding:1rem;background-color:#e3f2fd;border-left:4px solid #2196F3;border-radius:4px;font-size:.9rem}.legend-item{margin-bottom:.5rem;color:#555}.legend-item:last-child{margin-bottom:0}.legend-item strong{color:#333;margin-right:.5rem}@media (max-width: 768px){.yearly-metrics-container{padding:1rem}.metrics-header{flex-direction:column;align-items:flex-start;gap:1rem}.metrics-table{font-size:.85rem}.metrics-table th,.metrics-table td{padding:.5rem}.metrics-legend{font-size:.8rem}}.impact-modal{max-width:900px;width:95%;max-height:90vh;overflow-y:auto}.selection-section{background:#f8f9fa;padding:1.5rem;border-radius:8px;margin-bottom:1.5rem}.selection-card{background:#fff;padding:1rem;border-radius:6px;margin-bottom:1rem;border:1px solid #e0e0e0}.selection-card label{display:block;font-weight:600;color:#555;margin-bottom:.5rem;font-size:.9rem;text-transform:uppercase;letter-spacing:.5px}.candidate-card{border-left:4px solid #2196F3}.user-card{border-left:4px solid #4CAF50}.portfolio-info{padding:.5rem 0}.portfolio-name{font-size:1.1rem;font-weight:600;color:#333;margin-bottom:.25rem}.portfolio-owner{font-size:.9rem;color:#666;margin-bottom:.5rem}.portfolio-metrics{font-size:.9rem;color:#555}.portfolio-select{width:100%;padding:.75rem;font-size:1rem;border:2px solid #e0e0e0;border-radius:4px;background:#fff;cursor:pointer;transition:border-color .3s}.portfolio-select:hover{border-color:#4caf50}.portfolio-select:focus{outline:none;border-color:#4caf50;box-shadow:0 0 0 3px #4caf501a}.allocation-section{background:#fff;padding:1rem;border-radius:6px;border:1px solid #e0e0e0}.allocation-section label{display:flex;justify-content:space-between;align-items:center;font-weight:600;color:#555;margin-bottom:1rem;font-size:.9rem;text-transform:uppercase;letter-spacing:.5px}.allocation-value{font-size:1.2rem;color:#2196f3;font-weight:700}.allocation-visual{margin-bottom:1rem}.allocation-bar{display:flex;height:40px;border-radius:4px;overflow:hidden;box-shadow:0 2px 4px #0000001a}.allocation-keep{background:linear-gradient(135deg,#4caf50,#45a049);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:.9rem;transition:width .3s ease}.allocation-add{background:linear-gradient(135deg,#2196f3,#1976d2);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:.9rem;transition:width .3s ease}.allocation-slider{width:100%;height:8px;border-radius:4px;background:linear-gradient(to right,#4caf50,#2196f3);outline:none;cursor:pointer;-webkit-appearance:none}.allocation-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:#fff;border:3px solid #2196F3;cursor:pointer;box-shadow:0 2px 4px #0003;transition:transform .2s}.allocation-slider::-webkit-slider-thumb:hover{transform:scale(1.2)}.allocation-slider::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:#fff;border:3px solid #2196F3;cursor:pointer;box-shadow:0 2px 4px #0003;transition:transform .2s}.allocation-slider::-moz-range-thumb:hover{transform:scale(1.2)}.allocation-labels{display:flex;justify-content:space-between;margin-top:.25rem;font-size:.85rem;color:#666}.loading-section{text-align:center;padding:3rem 1rem}.loading-spinner{border:4px solid #f3f3f3;border-top:4px solid #2196F3;border-radius:50%;width:50px;height:50px;animation:spin 1s linear infinite;margin:0 auto 1rem}.loading-subtext{font-size:.9rem;color:#666;margin-top:.5rem}.impact-results{background:#fff;border-radius:8px;overflow:hidden}.results-header-row{display:grid;grid-template-columns:2fr 1.2fr .5fr 1.2fr 1.5fr;gap:.5rem;padding:1rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-weight:600;font-size:.9rem;text-align:center}.col-metric{text-align:left}.metric-row{display:grid;grid-template-columns:2fr 1.2fr .5fr 1.2fr 1.5fr;gap:.5rem;padding:1rem;border-bottom:1px solid #f0f0f0;align-items:center;transition:background .2s}.metric-row:hover{background:#f8f9fa}.metric-label{font-weight:600;color:#333;font-size:.95rem}.metric-current,.metric-projected{text-align:center;font-size:1rem;color:#555;font-weight:500}.metric-arrow{text-align:center;color:#999;font-size:1.2rem}.metric-delta{text-align:center;font-weight:700;font-size:1rem}.insights-section{margin-top:2rem;padding:1.5rem;background:#f8f9fa;border-radius:8px}.insights-section h3{margin:0 0 1rem;color:#333;font-size:1.1rem}.insight-card{background:#fff;padding:1rem;border-radius:6px;margin-bottom:.75rem;border:1px solid #e0e0e0;transition:box-shadow .2s}.insight-card:hover{box-shadow:0 2px 8px #0000001a}.insight-card.recommendation{border-left:4px solid #FF9800;background:#fff8e1}.insight-label{font-weight:600;color:#666;font-size:.9rem;margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.5px}.insight-value{color:#333;font-size:1rem;line-height:1.5}.insight-tag{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:600}.no-data{text-align:center;padding:3rem 1rem;color:#666;font-size:1.1rem}.error-message{background:#ffebee;border:1px solid #f44336;border-radius:6px;padding:1rem;margin-bottom:1rem;color:#c62828}.modal-footer{display:flex;justify-content:space-between;gap:1rem;padding-top:1rem;border-top:1px solid #e0e0e0}.modal-footer button{flex:1}@media (max-width: 768px){.impact-modal{width:98%;max-height:95vh}.results-header-row,.metric-row{grid-template-columns:1fr;text-align:left;gap:.25rem}.results-header-row{display:none}.metric-row{display:block;padding:1rem}.metric-label{font-size:.9rem;margin-bottom:.5rem}.metric-current:before{content:"Current: ";font-weight:400;color:#666}.metric-projected:before{content:"Projected: ";font-weight:400;color:#666}.metric-delta:before{content:"Change: ";font-weight:400;color:#666}.metric-arrow{display:none}.col-metric,.col-current,.col-projected,.col-delta{text-align:left!important}.modal-footer{flex-direction:column}}.role-compatibility-card{background:linear-gradient(135deg,#667eea15,#764ba215);border:2px solid #667eea30;padding:1.25rem!important}.role-badges-row{display:flex;align-items:center;gap:1rem;margin:1rem 0;flex-wrap:wrap}.role-badge-with-label{display:flex;flex-direction:column;gap:.5rem;flex:1;min-width:180px}.badge-label{font-size:.75rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.5px}.no-role-badge{padding:.5rem 1rem;background:#f1f5f9;border:1.5px dashed #cbd5e1;border-radius:12px;color:#94a3b8;font-size:.875rem;font-style:italic;text-align:center}.compatibility-arrow{font-size:1.5rem;color:#667eea;font-weight:700}.compatibility-rating{display:flex;align-items:center;gap:1rem;margin:1rem 0;padding:.75rem;background:#fff;border-radius:8px}.stars{font-size:1.25rem;letter-spacing:2px}.compatibility-label{font-weight:600;font-size:1rem;color:#1e293b}.compatibility-rationale{padding:.75rem;background:#fff;border-radius:8px;border-left:3px solid #667eea;color:#475569;font-size:.9rem;line-height:1.6}@media (max-width: 768px){.role-badges-row{flex-direction:column;align-items:stretch}.role-badge-with-label{min-width:100%}.compatibility-arrow{align-self:center;transform:rotate(90deg)}}.role-badge-container{display:inline-flex;flex-direction:column;align-items:flex-start;gap:.25rem}.role-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border:1.5px solid;border-radius:12px;font-weight:600;transition:all .2s ease;cursor:default}.role-badge:hover{transform:translateY(-1px);box-shadow:0 4px 8px #0000001a}.role-badge-small{padding:.25rem .5rem;font-size:.75rem;border-radius:8px}.role-badge-small .role-emoji{font-size:.875rem}.role-badge-medium{padding:.5rem 1rem;font-size:.875rem;border-radius:12px}.role-badge-medium .role-emoji{font-size:1rem}.role-badge-large{padding:.75rem 1.25rem;font-size:1rem;border-radius:14px}.role-badge-large .role-emoji{font-size:1.25rem}.role-emoji{line-height:1}.role-name{white-space:nowrap}.role-meta{display:flex;gap:.5rem;font-size:.75rem;color:#64748b;padding-left:.5rem}.confidence-text{font-weight:500}.set-by-text{font-style:italic}.role-badge-inline{display:inline-flex;margin-left:.5rem;vertical-align:middle}.optimization-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000;padding:20px}.optimization-modal{background:#fff;border-radius:12px;max-width:1400px;width:95%;max-height:90vh;overflow-y:auto;box-shadow:0 10px 40px #0000004d}.modal-header{display:flex;justify-content:space-between;align-items:start;padding:24px;border-bottom:2px solid #e0e0e0;position:sticky;top:0;background:#fff;z-index:10}.modal-header h2{margin:0;font-size:1.5rem;color:#2c3e50}.modal-subtitle{margin:8px 0 0;font-size:.9rem;color:#7f8c8d}.close-button{background:none;border:none;font-size:2rem;color:#95a5a6;cursor:pointer;line-height:1;padding:0;width:32px;height:32px;border-radius:50%;transition:all .2s}.close-button:hover{background:#ecf0f1;color:#2c3e50}.optimization-modal-content{padding:24px}.loading-state,.error-state{text-align:center;padding:60px 20px}.spinner{border:4px solid #f3f3f3;border-top:4px solid #3498db;border-radius:50%;width:50px;height:50px;animation:spin 1s linear infinite;margin:0 auto 20px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-subtitle{color:#7f8c8d;font-size:.9rem;margin-top:8px}.error-icon{font-size:3rem;margin-bottom:16px}.error-message{color:#e74c3c;font-size:1.1rem;margin-bottom:20px}.insights-container{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:12px;padding:24px;margin-bottom:24px}.insights-container h3{margin:0 0 20px;font-size:1.3rem}.insights-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px;margin-bottom:24px}.insight-card{background:#ffffff26;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:8px;padding:16px;display:flex;align-items:center;gap:12px}.insight-icon{font-size:2rem}.insight-content{flex:1}.insight-label{font-size:.85rem;opacity:.9;margin-bottom:4px}.insight-value{font-size:1rem;font-weight:600;margin-bottom:4px}.insight-metric{font-size:1.3rem;font-weight:700}.diversification-section{margin-top:20px;padding-top:20px;border-top:1px solid rgba(255,255,255,.3)}.diversification-section h4{margin:0 0 12px;font-size:1rem;opacity:.9}.diversification-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px}.diversification-item{background:#ffffff26;padding:12px 16px;border-radius:6px;display:flex;justify-content:space-between;align-items:center}.div-algorithm{font-size:.9rem}.div-score{font-size:1.2rem;font-weight:700}.strategy-tabs{display:flex;gap:12px;margin-bottom:24px;flex-wrap:wrap}.strategy-tab{flex:1;min-width:200px;background:#fff;border:2px solid #e0e0e0;border-radius:8px;padding:16px;cursor:pointer;transition:all .2s;text-align:center}.strategy-tab:hover{border-color:#3498db;transform:translateY(-2px);box-shadow:0 4px 12px #3498db33}.strategy-tab.active{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea;color:#fff}.tab-name{font-weight:600;font-size:1rem;margin-bottom:8px}.tab-return{font-size:1.3rem;font-weight:700}.strategy-details{background:#f8f9fa;border-radius:12px;padding:24px;margin-bottom:24px}.strategy-header{margin-bottom:20px}.strategy-header h3{margin:0 0 8px;color:#2c3e50}.strategy-description{color:#7f8c8d;font-size:.95rem;margin:0}.metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:16px;margin-bottom:24px}.metric-card{background:#fff;border-radius:8px;padding:16px;text-align:center;box-shadow:0 2px 8px #0000001a}.metric-label{font-size:.85rem;color:#7f8c8d;margin-bottom:8px}.metric-value{font-size:1.5rem;font-weight:700;color:#2c3e50}.weights-section{margin-bottom:24px}.weights-section h4{margin:0 0 16px;color:#2c3e50}.weights-chart{display:flex;flex-direction:column;gap:12px}.weight-bar-container{display:flex;flex-direction:column;gap:4px}.weight-label{display:flex;justify-content:space-between;align-items:center;font-size:.9rem}.weight-label .ticker{font-weight:600;color:#2c3e50}.weight-label .weight-value{color:#7f8c8d}.weight-bar-track{height:24px;background:#e0e0e0;border-radius:4px;overflow:hidden}.weight-bar-fill{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);transition:width .3s ease}.auto-create-section{background:#fff;border-radius:8px;padding:20px;border:2px solid #e0e0e0}.auto-create-header{margin-bottom:16px}.checkbox-label{display:flex;align-items:center;gap:8px;font-size:1.1rem;font-weight:600;color:#2c3e50;cursor:pointer}.checkbox-label input[type=checkbox]{width:20px;height:20px;cursor:pointer}.auto-create-form{padding-top:16px;border-top:1px solid #e0e0e0}.form-row{display:grid;grid-template-columns:1fr 2fr;gap:16px;margin-bottom:16px}.form-group{display:flex;flex-direction:column}.form-group label{font-size:.9rem;font-weight:600;color:#2c3e50;margin-bottom:6px}.form-control{padding:10px 12px;border:1px solid #ddd;border-radius:6px;font-size:.95rem}.form-control:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 3px #3498db1a}.create-info{background:#e8f4f8;border-left:4px solid #3498db;padding:16px;border-radius:4px;margin-bottom:16px}.create-info strong{color:#2c3e50}.create-info ul{margin:8px 0 0;padding-left:20px}.create-info li{color:#34495e;margin:4px 0}.btn-create{width:100%;padding:14px;font-size:1.1rem;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:all .2s}.btn-create:disabled{opacity:.6;cursor:not-allowed}.comparison-table-section{margin-top:24px}.comparison-table-section h3{margin:0 0 16px;color:#2c3e50}.table-responsive{overflow-x:auto}.comparison-table{width:100%;border-collapse:collapse;background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 2px 8px #0000001a}.comparison-table thead{background:#2c3e50;color:#fff}.comparison-table th{padding:14px 16px;text-align:left;font-weight:600;font-size:.9rem}.comparison-table tbody tr{border-bottom:1px solid #e0e0e0;cursor:pointer;transition:background-color .2s}.comparison-table tbody tr:hover{background-color:#f8f9fa}.comparison-table tbody tr.selected-row{background-color:#e8f4f8;font-weight:600}.comparison-table td{padding:14px 16px;font-size:.95rem}.algorithm-name{font-weight:600;color:#2c3e50}.weights-comparison-table .ticker-name{font-weight:700;color:#2c3e50;background-color:#f8f9fa;font-size:1rem}.weights-comparison-table tbody tr:hover .ticker-name{background-color:#e9ecef}.weights-comparison-table td{text-align:center}.weights-comparison-table .ticker-name{text-align:left}.weights-comparison-table thead th{text-align:center}.weights-comparison-table thead th:first-child{text-align:left}@media (max-width: 768px){.optimization-modal{width:100%;max-height:100vh;border-radius:0}.insights-grid{grid-template-columns:1fr}.strategy-tabs{flex-direction:column}.strategy-tab{min-width:100%}.metrics-grid{grid-template-columns:repeat(2,1fr)}.form-row{grid-template-columns:1fr}}.dashboard-container{max-width:1400px;margin:0 auto;padding:32px 24px}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px}.dashboard-header h1{font-size:32px;font-weight:700;color:#1e293b;margin-bottom:4px}.dashboard-header p{color:#64748b;font-size:16px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-bottom:32px}.stat-card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 1px 3px #0000001a;border-left:4px solid #2563eb;cursor:pointer;transition:all .2s}.stat-card:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.stat-card-primary{border-left-color:#2563eb}.stat-card-success{border-left-color:#10b981}.stat-card-warning{border-left-color:#f59e0b}.stat-card-info{border-left-color:#06b6d4}.stat-label{font-size:14px;color:#64748b;margin-bottom:8px;font-weight:500}.stat-value{font-size:32px;font-weight:700;color:#1e293b}.stat-subtitle{font-size:12px;color:#94a3b8;margin-top:4px}.deals-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px}.deal-card{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:20px;cursor:pointer;transition:all .2s}.deal-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px);border-color:#2563eb}.deal-card h3{font-size:18px;font-weight:600;color:#1e293b;margin-bottom:8px}.deal-description{font-size:14px;color:#64748b;margin-bottom:16px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.deal-meta{display:grid;gap:8px;margin-bottom:16px}.deal-meta-item{display:flex;justify-content:space-between;font-size:14px}.deal-meta-item .label{color:#64748b;font-weight:500}.deal-progress{margin-top:16px}.progress-bar{height:8px;background-color:#e2e8f0;border-radius:4px;overflow:hidden;margin-bottom:6px}.progress-fill{height:100%;background-color:#2563eb;transition:width .3s}.progress-text{font-size:12px;color:#64748b;text-align:right}.table-container{overflow-x:auto}.table{width:100%;border-collapse:collapse}.table thead{background-color:#f8fafc}.table th{text-align:left;padding:12px;font-weight:600;color:#475569;font-size:13px;text-transform:uppercase;letter-spacing:.5px}.table td{padding:16px 12px;border-top:1px solid #e2e8f0;font-size:14px;color:#1e293b}.table tr:hover{background-color:#f8fafc}.deal-name{font-weight:600;color:#2563eb}.mini-progress{width:100px;height:6px;background-color:#e2e8f0;border-radius:3px;overflow:hidden;display:inline-block;margin-right:8px}.mini-progress-fill{height:100%;background-color:#2563eb}.card-header-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.deal-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}.deal-card-header h3{margin:0;flex:1}.empty-state{text-align:center;padding:48px 24px;color:#64748b}.empty-state p{margin-bottom:20px;font-size:16px}.highlight{color:#10b981;font-weight:600}.amount-cell{font-weight:600;color:#059669}.deal-cell{display:flex;flex-direction:column}.deal-title{font-weight:600;color:#1e293b}.deal-subtitle{font-size:12px;color:#64748b;margin-top:2px}.filters-container{display:flex;gap:16px;margin-bottom:24px}.search-box{flex:1}.filter-box{min-width:200px}.profile-view{display:flex;flex-direction:column;gap:32px}.profile-section h3{font-size:18px;font-weight:600;color:#1e293b;margin-bottom:16px;padding-bottom:8px;border-bottom:2px solid #e2e8f0}.profile-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px}.profile-item{display:flex;flex-direction:column;gap:4px}.profile-label{font-size:13px;color:#64748b;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.profile-value{font-size:15px;color:#1e293b;font-weight:500}.profile-form{display:flex;flex-direction:column;gap:20px}.form-actions{display:flex;gap:12px;padding-top:8px}.form-help{font-size:12px;color:#64748b;margin-top:4px}.security-section{padding:20px 0}.security-section p{color:#64748b;margin-bottom:16px}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:24px;padding:20px;background-color:#f8fafc;border-radius:8px}.summary-item{display:flex;flex-direction:column;gap:8px}.summary-label{font-size:13px;color:#64748b;font-weight:500}.summary-value{font-size:24px;font-weight:700;color:#1e293b}@media (max-width: 768px){.dashboard-header{flex-direction:column;align-items:flex-start;gap:16px}.deals-grid,.stats-grid{grid-template-columns:1fr}.filters-container{flex-direction:column}.filter-box{width:100%}.card-header-row{flex-direction:column;align-items:flex-start;gap:12px}.profile-grid,.summary-grid{grid-template-columns:1fr}.form-actions{flex-direction:column}.form-actions button{width:100%}}.verification-badge{display:inline-flex;align-items:center;justify-content:center;border-radius:50%;font-weight:700;margin-left:.25rem;cursor:help;vertical-align:middle}.verification-badge.verified{background-color:#4caf50;color:#fff;width:1.5em;height:1.5em;box-shadow:0 2px 4px #4caf504d}.verification-badge.custom{padding:.25rem;box-shadow:0 2px 4px #0003}.verification-badge.expired{opacity:.5;filter:grayscale(100%)}.badge-list{display:inline-flex;gap:.25rem;align-items:center;flex-wrap:wrap}.badge-count{font-size:.85em;color:#666;margin-left:.25rem}.deal-detail-card{background:#fff;border-radius:12px;padding:32px;box-shadow:0 1px 3px #0000001a}.deal-detail-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:32px;padding-bottom:24px;border-bottom:2px solid #e2e8f0}.deal-detail-header h1{font-size:32px;font-weight:700;color:#1e293b;margin-bottom:8px}.commit-form{background-color:#f8fafc;padding:24px;border-radius:8px;margin-bottom:32px;border:2px solid #2563eb}.commit-form h3{font-size:20px;font-weight:600;color:#1e293b;margin-bottom:16px}.btn-lg{padding:12px 24px;font-size:16px;font-weight:600}.deal-description{margin-bottom:32px}.deal-description h3{font-size:20px;font-weight:600;color:#1e293b;margin-bottom:12px}.deal-description p{font-size:16px;line-height:1.6;color:#475569}.deal-details-section{margin-bottom:32px}.deal-details-section h3{font-size:20px;font-weight:600;color:#1e293b;margin-bottom:16px}.deal-details-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:24px}.detail-item{display:flex;flex-direction:column;gap:4px}.detail-label{font-size:13px;color:#64748b;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.detail-value{font-size:20px;font-weight:700;color:#1e293b}.highlight-green{color:#10b981}.deal-progress-section{margin-top:32px;padding-top:32px;border-top:2px solid #e2e8f0}.deal-progress-section h3{font-size:20px;font-weight:600;color:#1e293b;margin-bottom:16px}.progress-bar-large{height:24px;background-color:#e2e8f0;border-radius:12px;overflow:hidden;margin-bottom:12px}.progress-fill-large{height:100%;background:linear-gradient(90deg,#2563eb,#3b82f6);transition:width .3s}.progress-stats{display:flex;justify-content:space-between;font-size:14px;color:#64748b;font-weight:500}@media (max-width: 768px){.deal-detail-header{flex-direction:column;gap:16px}.deal-details-grid{grid-template-columns:1fr}}.form-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-in}.form-modal{background:#fff;border-radius:12px;box-shadow:0 20px 60px #00000026;max-width:600px;width:90%;max-height:90vh;overflow-y:auto;animation:slideUp .3s ease-out}.form-modal-header{padding:24px 32px;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;align-items:center}.form-modal-header h2{margin:0;font-size:20px;font-weight:600;color:#111827}.form-modal-close{background:none;border:none;font-size:24px;color:#6b7280;cursor:pointer;padding:4px 8px;line-height:1;transition:color .2s}.form-modal-close:hover{color:#111827}.form-modal-body{padding:32px}.form-group{margin-bottom:24px}.form-group:last-child{margin-bottom:0}.form-label{display:block;margin-bottom:8px;font-size:14px;font-weight:500;color:#374151;letter-spacing:.01em}.form-label-required:after{content:" *";color:#dc2626}.form-input,.form-select,.form-textarea{width:100%;padding:10px 14px;font-size:15px;color:#111827;background-color:#fff;border:1px solid #d1d5db;border-radius:8px;transition:all .2s;font-family:inherit;box-sizing:border-box}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-input::placeholder{color:#9ca3af}.form-textarea{min-height:100px;resize:vertical}.form-select{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3E%3Cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;background-size:20px;padding-right:40px}.form-input-error{border-color:#dc2626}.form-input-error:focus{border-color:#dc2626;box-shadow:0 0 0 3px #dc26261a}.form-error-message{margin-top:6px;font-size:13px;color:#dc2626}.form-helper-text{margin-top:6px;font-size:13px;color:#6b7280}.form-row{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}@media (max-width: 768px){.form-row{grid-template-columns:1fr}}.form-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:32px;padding-top:24px;border-top:1px solid #e5e7eb}.form-button{padding:10px 20px;font-size:15px;font-weight:500;border-radius:8px;border:none;cursor:pointer;transition:all .2s;font-family:inherit}.form-button-primary{background-color:#3b82f6;color:#fff}.form-button-primary:hover:not(:disabled){background-color:#2563eb;transform:translateY(-1px);box-shadow:0 4px 12px #3b82f64d}.form-button-primary:active:not(:disabled){transform:translateY(0)}.form-button-primary:disabled{background-color:#9ca3af;cursor:not-allowed;opacity:.6}.form-button-secondary{background-color:#f3f4f6;color:#374151}.form-button-secondary:hover:not(:disabled){background-color:#e5e7eb}.form-button-danger{background-color:#dc2626;color:#fff}.form-button-danger:hover:not(:disabled){background-color:#b91c1c}.form-button-success{background-color:#10b981;color:#fff}.form-button-success:hover:not(:disabled){background-color:#059669}.form-loading{display:inline-flex;align-items:center;gap:8px}.form-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}.form-input-group{display:flex;align-items:stretch}.form-input-group-prefix,.form-input-group-suffix{display:flex;align-items:center;padding:10px 14px;background-color:#f9fafb;border:1px solid #d1d5db;color:#6b7280;font-size:15px;white-space:nowrap}.form-input-group-prefix{border-right:none;border-radius:8px 0 0 8px}.form-input-group-suffix{border-left:none;border-radius:0 8px 8px 0}.form-input-group .form-input{border-radius:0}.form-input-group .form-input:first-child{border-radius:8px 0 0 8px}.form-input-group .form-input:last-child{border-radius:0 8px 8px 0}.form-checkbox-group,.form-radio-group{display:flex;flex-direction:column;gap:12px}.form-checkbox-label,.form-radio-label{display:flex;align-items:center;gap:10px;cursor:pointer;font-size:15px;color:#374151}.form-checkbox-label input[type=checkbox],.form-radio-label input[type=radio]{width:18px;height:18px;cursor:pointer}.navbar{background-color:#1e293b;color:#fff;padding:0;box-shadow:0 2px 4px #0000001a}.navbar-container{max-width:1400px;margin:0 auto;padding:16px 24px;display:flex;justify-content:space-between;align-items:center;gap:32px}.navbar-brand{font-size:20px;font-weight:700;cursor:pointer;transition:color .2s}.navbar-brand:hover{color:#3b82f6}.navbar-links{display:flex;align-items:center;gap:8px;flex:1}.navbar-link{background:transparent;border:none;color:#cbd5e1;padding:8px 16px;font-size:15px;font-weight:500;cursor:pointer;border-radius:6px;transition:all .2s}.navbar-link:hover{background-color:#334155;color:#fff}.navbar-link.active{background-color:#3b82f6;color:#fff}.navbar-menu{display:flex;align-items:center;gap:20px}.navbar-user{font-size:14px;color:#cbd5e1}.btn-sm{padding:6px 14px;font-size:13px}.footer{background-color:#2c3e50;color:#ecf0f1;padding:2rem 0;margin-top:4rem;border-top:4px solid #3498db}.footer-container{max-width:1200px;margin:0 auto;padding:0 2rem;display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem}.footer-section{padding:0}.footer-section h4{color:#3498db;margin-bottom:1rem;font-size:1.1rem;font-weight:600}.footer-links{list-style:none;padding:0;margin:0}.footer-links li{margin-bottom:.5rem}.footer-link{background:none;border:none;color:#bdc3c7;cursor:pointer;font-size:.95rem;padding:0;text-align:left;transition:color .2s}.footer-link:hover{color:#3498db;text-decoration:underline}@media (max-width: 768px){.footer-container{grid-template-columns:1fr}.footer{margin-top:2rem;padding:1.5rem 0}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f7fa}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.container{max-width:1200px;margin:0 auto;padding:20px}.btn{padding:10px 20px;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s}.btn-primary{background-color:#2563eb;color:#fff}.btn-primary:hover{background-color:#1d4ed8}.btn-secondary{background-color:#64748b;color:#fff}.btn-secondary:hover{background-color:#475569}.btn-success{background-color:#16a34a;color:#fff}.btn-success:hover{background-color:#15803d}.btn-warning{background-color:#f59e0b;color:#fff}.btn-warning:hover{background-color:#d97706}.btn-danger{background-color:#dc2626;color:#fff}.btn-danger:hover{background-color:#b91c1c}.form-group{margin-bottom:16px}.form-label{display:block;margin-bottom:6px;font-weight:500;color:#374151}.form-input,.form-select,.form-textarea{width:100%;padding:10px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.form-textarea{resize:vertical;min-height:100px}.card{background:#fff;border-radius:8px;padding:24px;box-shadow:0 1px 3px #0000001a;margin-bottom:20px}.card-header{font-size:18px;font-weight:600;margin-bottom:16px;color:#111827}.grid{display:grid;gap:20px}.grid-2{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.grid-3{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:500}.badge-success{background-color:#dcfce7;color:#166534}.badge-warning{background-color:#fef3c7;color:#92400e}.badge-info{background-color:#dbeafe;color:#1e40af}.badge-danger{background-color:#fee2e2;color:#991b1b}.loading{text-align:center;padding:40px;color:#6b7280}.error{background-color:#fee2e2;color:#991b1b;padding:12px 16px;border-radius:6px;margin-bottom:16px}.success{background-color:#dcfce7;color:#166534;padding:12px 16px;border-radius:6px;margin-bottom:16px}
