.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.login-box{background:#fff;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 8px 10px -6px #0000001a;width:100%;max-width:420px;padding:40px}.login-header{text-align:center;margin-bottom:32px}.login-header h1{font-size:28px;font-weight:700;color:var(--text-primary);margin-bottom:8px}.login-header p{font-size:14px;color:var(--text-secondary)}.login-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-size:14px;font-weight:500;color:var(--text-primary)}.error-message{padding:12px;background:#fef2f2;border:1px solid #fecaca;border-radius:6px;color:#dc2626;font-size:14px}.btn-full{width:100%;padding:12px;font-size:16px}.header{background:#fff;border-bottom:1px solid var(--border-color);box-shadow:var(--shadow)}.header-content{display:flex;justify-content:space-between;align-items:center;padding:20px 0}.header-logo h1{font-size:24px;font-weight:700;color:var(--text-primary)}.btn-logout{background:transparent;color:var(--text-secondary);border:1px solid var(--border-color);padding:8px 16px;font-size:14px}.btn-logout:hover{background:#f8fafc;color:var(--text-primary)}.portfolio-stats{display:grid;grid-template-columns:1fr 1fr;gap:20px}@media (max-width: 768px){.portfolio-stats{grid-template-columns:1fr}}.stat-card{background:#fff;border-radius:8px;box-shadow:var(--shadow);padding:24px}.stat-card-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.stat-label{font-size:14px;font-weight:500;opacity:.9;margin-bottom:8px}.stat-card-primary .stat-label{color:#ffffffe6}.stat-value{font-size:32px;font-weight:700}.stat-currencies{display:flex;flex-direction:column;gap:12px}.currency-item{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--border-color)}.currency-item:last-child{border-bottom:none}.currency-label{font-size:14px;font-weight:600;color:var(--text-secondary)}.currency-value{font-size:18px;font-weight:600;color:var(--text-primary)}.table-wrapper{overflow-x:auto}.positions-table{width:100%;border-collapse:collapse;font-size:14px}.positions-table thead{background:#f8fafc}.positions-table th{padding:12px 16px;text-align:left;font-weight:600;color:var(--text-secondary);border-bottom:2px solid var(--border-color);font-size:13px;text-transform:uppercase;letter-spacing:.5px}.positions-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .2s}.positions-table th.sortable:hover{background:#f1f5f9;color:var(--text-primary)}.positions-table td{padding:16px;border-bottom:1px solid var(--border-color);color:var(--text-primary)}.positions-table tbody tr:hover{background:#f8fafc}.positions-table tbody tr:last-child td{border-bottom:none}.text-right{text-align:right}.ticker-cell{font-weight:600;color:var(--primary-color)}.name-cell{color:var(--text-secondary);max-width:250px;position:relative;cursor:help}.name-cell:hover{color:var(--text-primary)}.name-cell-content{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.position-tooltip{position:absolute;left:0;background:#fff;border:1px solid var(--border-color);border-radius:8px;padding:12px 16px;box-shadow:0 4px 12px #00000026;z-index:1000;min-width:250px;white-space:normal}.position-tooltip.tooltip-above{bottom:100%;margin-bottom:8px}.position-tooltip.tooltip-below{top:100%;margin-top:8px}.tooltip-header{font-size:15px;margin-bottom:8px;color:var(--primary-color)}.tooltip-row{display:flex;justify-content:space-between;padding:4px 0;font-size:13px}.tooltip-label{color:var(--text-secondary);margin-right:12px}.tooltip-value{color:var(--text-primary);font-weight:500}.tooltip-divider{height:1px;background:var(--border-color);margin:8px 0}.tooltip-section{margin-top:8px}.tooltip-section-title{font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.missing-instrument{font-size:18px;cursor:help;filter:grayscale(20%)}.value-cell{font-weight:600}.profit-cell{line-height:1.3}.profit-percentage{font-size:12px;opacity:.85}.percentage-cell{min-width:150px}.percentage-wrapper{display:flex;align-items:center}.percentage-bar{flex:1;height:24px;background:#e2e8f0;border-radius:4px;overflow:hidden;position:relative}.percentage-fill{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);transition:width .3s ease;border-radius:4px;position:relative}.percentage-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-weight:600;color:var(--text-primary);font-size:12px;z-index:1;white-space:nowrap}.empty-state{text-align:center;padding:60px 20px;color:var(--text-secondary);font-size:16px}@media (max-width: 768px){.positions-table{font-size:12px}.positions-table th,.positions-table td{padding:8px 12px}}.dashboard{min-height:100vh;background:#f8fafc}.dashboard-content{padding:32px 0;display:flex;flex-direction:column;gap:24px}.section-title{font-size:20px;font-weight:600;color:var(--text-primary);margin-bottom:20px}.chart-section,.table-section{width:100%}.loading{text-align:center;padding:60px 20px;font-size:18px;color:var(--text-secondary)}.error-box{padding:20px;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;text-align:center;margin-top:40px}.chart-container{display:flex;align-items:flex-start;gap:60px;padding:20px 0;min-height:500px}.chart-wrapper{flex:0 0 550px;height:500px}.chart-legend{flex:1;max-width:350px;display:flex;flex-direction:column;max-height:500px}.legend-title{font-size:12px;font-weight:600;color:var(--text-secondary);margin-bottom:16px;letter-spacing:.5px;flex-shrink:0}.legend-items{flex:1;overflow-y:auto;padding-right:8px}.legend-items::-webkit-scrollbar{width:6px}.legend-items::-webkit-scrollbar-track{background:#f1f5f9;border-radius:3px}.legend-items::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.legend-items::-webkit-scrollbar-thumb:hover{background:#94a3b8}.legend-item{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid #f1f5f9}.legend-item:last-child{border-bottom:none}.legend-color{width:12px;height:12px;border-radius:50%;flex-shrink:0}.legend-content{display:flex;justify-content:space-between;align-items:center;flex:1}.legend-name{font-size:14px;font-weight:500;color:var(--text-primary)}.legend-percentage{font-size:14px;font-weight:600;color:var(--text-primary)}@media (max-width: 968px){.chart-container{flex-direction:column;gap:24px}.chart-wrapper{flex:none;width:100%}.chart-legend{max-width:100%;width:100%}}.investment-distribution-container{display:grid;grid-template-columns:1fr 1fr;gap:30px;padding:20px 0}.distribution-chart{display:flex;flex-direction:column}.distribution-chart-title{font-size:16px;font-weight:600;color:var(--text-primary);margin-bottom:20px;text-align:center}.distribution-chart .chart-container{display:flex;align-items:center;gap:30px}.distribution-chart .chart-wrapper{flex:0 0 300px;height:300px}.distribution-chart .chart-legend{flex:1;max-width:250px}.distribution-chart-empty{min-height:300px;display:flex;align-items:center;justify-content:center}.chart-view-switcher{display:inline-flex;gap:0;margin-bottom:24px;padding:3px;background:#f1f5f9;border-radius:10px;box-shadow:inset 0 1px 3px #0000000f}.chart-view-button{padding:10px 20px;background:transparent;border:none;border-radius:8px;font-size:14px;font-weight:500;color:#64748b;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);white-space:nowrap;position:relative}.chart-view-button:hover:not(.active){color:#475569;background:#ffffff80}.chart-view-button.active{background:#fff;color:#4169e1;box-shadow:0 2px 8px #4169e126,0 1px 3px #0000001a;font-weight:600}.asset-type-filter{margin-bottom:24px;padding:20px 24px;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-radius:12px;border:1px solid #e2e8f0}.asset-type-filter-title{font-size:13px;font-weight:700;color:#334155;margin-bottom:16px;text-transform:uppercase;letter-spacing:.5px}.asset-type-checkboxes{display:flex;flex-wrap:wrap;gap:10px}.asset-type-checkbox{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;background:#fff;border:2px solid #e2e8f0;border-radius:8px;cursor:pointer;-webkit-user-select:none;user-select:none;transition:all .2s ease}.asset-type-checkbox:hover{border-color:#cbd5e1;background:#fafbfc;transform:translateY(-1px);box-shadow:0 2px 4px #0000000d}.asset-type-checkbox.checked{background:linear-gradient(135deg,#4169e1,#5b7fe8);border-color:#4169e1}.asset-type-checkbox.checked label{color:#fff;font-weight:600}.asset-type-checkbox input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:#4169E1}.asset-type-checkbox label{font-size:14px;color:#475569;cursor:pointer;font-weight:500;transition:color .2s ease}@media (max-width: 1200px){.investment-distribution-container{grid-template-columns:1fr;gap:40px}.distribution-chart .chart-wrapper{flex:0 0 350px}}@media (max-width: 768px){.distribution-chart .chart-container{flex-direction:column;gap:24px}.distribution-chart .chart-wrapper{flex:none;width:100%}.distribution-chart .chart-legend{max-width:100%;width:100%}.asset-type-checkboxes{gap:8px}.asset-type-checkbox{flex:1 1 calc(50% - 4px);min-width:140px}.chart-view-switcher{width:100%}.chart-view-button{flex:1;text-align:center}}*{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:#f5f5f5;color:#333}:root{--primary-color: #2563eb;--secondary-color: #64748b;--success-color: #10b981;--danger-color: #ef4444;--warning-color: #f59e0b;--background: #ffffff;--text-primary: #1e293b;--text-secondary: #64748b;--border-color: #e2e8f0;--shadow: 0 1px 3px 0 rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1)}#root{min-height:100vh}.container{max-width:1400px;margin:0 auto;padding:0 20px}.card{background:var(--background);border-radius:8px;box-shadow:var(--shadow);padding:24px}.btn{padding:10px 20px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.btn-primary{background:var(--primary-color);color:#fff}.btn-primary:hover{opacity:.9}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.input{width:100%;padding:10px 14px;border:1px solid var(--border-color);border-radius:6px;font-size:14px;transition:all .2s}.input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #2563eb1a}.text-center{text-align:center}.mt-1{margin-top:8px}.mt-2{margin-top:16px}.mt-3{margin-top:24px}.mt-4{margin-top:32px}.mb-1{margin-bottom:8px}.mb-2{margin-bottom:16px}.mb-3{margin-bottom:24px}.mb-4{margin-bottom:32px}
