.category-type-selector{display:flex;flex-direction:column;gap:15px;padding:15px;border:1px solid #e0e0e0;border-radius:8px;background-color:#fafafa}.category-type-selector.error,.category-type-selector.loading{text-align:center;padding:20px;color:#666}.category-type-selector.error{color:#d32f2f;border-color:#d32f2f;background-color:#ffebee}.selector-group{display:flex;flex-direction:column;gap:5px}.selector-group label{font-weight:500;color:#333;font-size:14px}.category-select,.type-select{padding:10px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px;background-color:white;transition:border-color .2s ease}.category-select:focus,.type-select:focus{outline:none;border-color:#1976d2;box-shadow:0 0 0 2px rgba(25,118,210,.1)}.category-select:disabled,.type-select:disabled{background-color:#f5f5f5;color:#999;cursor:not-allowed}.category-info{padding:10px;background-color:white;border-radius:6px;border:1px solid #e0e0e0}.category-color{border:1px solid #ddd}.category-description{font-size:13px;color:#666;font-style:italic}@media (max-width:768px){.category-type-selector{padding:10px}.category-select,.type-select{padding:8px 10px;font-size:16px}}.category-chart{background:white;border-radius:12px;box-shadow:0 4px 6px rgba(0,0,0,.1);padding:20px;margin:10px;min-width:400px;max-width:500px;position:relative;border:1px solid #e0e0e0}.chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:15px;border-bottom:1px solid #f0f0f0}.chart-title{margin:0;font-size:18px;font-weight:600;color:#333}.chart-total{display:flex;flex-direction:column;align-items:flex-end;gap:4px}.total-label{font-size:12px;color:#666;font-weight:500}.total-value{font-size:16px;font-weight:700;color:#2c3e50}.remove-chart-btn{background:#ff4757;color:white;border:none;border-radius:50%;width:30px;height:30px;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;position:absolute;top:15px;right:15px}.remove-chart-btn:hover{background:#ff3742;transform:scale(1.1)}.chart-container{position:relative;height:300px}.chart-tooltip{background:rgba(0,0,0,.9);color:white;padding:12px;border-radius:8px;font-size:14px;box-shadow:0 4px 12px rgba(0,0,0,.3)}.tooltip-name{font-weight:600;margin:0 0 8px;color:#fff}.tooltip-value{font-size:16px;font-weight:700;margin:0 0 4px;color:#4CAF50}.tooltip-percentage{font-size:12px;margin:0;color:#ccc}.chart-legend{display:flex;flex-direction:column;gap:8px;margin-top:15px;padding:15px;background:#f8f9fa;border-radius:8px;max-height:200px;overflow-y:auto}.legend-item{display:flex;align-items:center;gap:10px;padding:4px 0}.legend-color{width:16px;height:16px;border-radius:3px;flex-shrink:0}.legend-text{font-size:14px;font-weight:500;color:#333;flex:1 1}.legend-value{font-size:12px;color:#666;font-weight:600}@media (max-width:768px){.category-chart{min-width:100%;margin:10px 0}.chart-header{flex-direction:column;gap:10px}.chart-header,.chart-total{align-items:flex-start}.remove-chart-btn{position:static;align-self:flex-end}}.modal-overlay{background:rgba(0,0,0,.5)!important;padding:20px!important}.modal-content{background:white!important;border-radius:12px!important;padding:30px!important;max-width:500px!important;width:100%!important;box-shadow:0 10px 30px rgba(0,0,0,.3)!important;position:relative!important;animation:modalSlideIn .3s ease-out!important;opacity:1!important;visibility:visible!important}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{display:flex!important;justify-content:space-between!important;align-items:center!important;margin-bottom:25px!important;padding-bottom:15px!important;border-bottom:1px solid #e9ecef!important}.modal-header h2{margin:0!important;font-size:20px!important;font-weight:600!important;color:#2c3e50!important}.close-btn{background:none!important;border:none!important;font-size:24px!important;color:#6c757d!important;cursor:pointer!important;padding:0!important;width:30px!important;height:30px!important;display:flex!important;align-items:center!important;justify-content:center!important;border-radius:50%!important;transition:all .2s ease!important}.close-btn:hover{background:#f8f9fa!important;color:#495057!important}.modal-form{gap:20px!important}.form-group,.modal-form{display:flex!important;flex-direction:column!important}.form-group{gap:8px!important}.form-group label{font-weight:600!important;color:#495057!important;font-size:14px!important}.category-select{padding:12px 16px!important;border:2px solid #e9ecef!important;border-radius:8px!important;font-size:16px!important;background:white!important;transition:border-color .2s ease!important;cursor:pointer!important}.category-select:focus{outline:none!important;border-color:#667eea!important;box-shadow:0 0 0 3px rgba(102,126,234,.1)!important}.category-select:hover{border-color:#ced4da!important}.no-categories-message{background:#f8f9fa!important;border:1px solid #dee2e6!important;border-radius:8px!important;padding:20px!important;text-align:center!important;color:#6c757d!important}.no-categories-message p{margin:8px 0!important;font-size:14px!important;line-height:1.5!important}.modal-actions{display:flex!important;gap:12px!important;justify-content:flex-end!important;margin-top:10px!important}.btn{padding:12px 24px!important;border-radius:8px!important;font-size:14px!important;font-weight:600!important;cursor:pointer!important;transition:all .2s ease!important;border:none!important;min-width:100px!important}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2)!important;color:white!important;box-shadow:0 4px 12px rgba(102,126,234,.3)!important}.btn-primary:hover:not(:disabled){transform:translateY(-1px)!important;box-shadow:0 6px 20px rgba(102,126,234,.4)!important}.btn-primary:disabled{opacity:.6!important;cursor:not-allowed!important;transform:none!important;box-shadow:none!important}.btn-secondary{background:#6c757d!important;color:white!important}.btn-secondary:hover{background:#5a6268!important;transform:translateY(-1px)!important}@media (max-width:768px){.modal-overlay{padding:10px!important}.modal-content{padding:20px!important}.modal-header h2{font-size:18px!important}.modal-actions{flex-direction:column!important}.btn{width:100%!important;justify-content:center!important}}@media (max-width:480px){.modal-content{padding:15px!important}.modal-header{margin-bottom:20px!important}.modal-header h2{font-size:16px!important}.category-select{padding:10px 12px!important;font-size:14px!important}}.category-selector-modal{position:fixed!important;top:0!important;left:0!important;right:0!important;bottom:0!important;background:rgba(0,0,0,.5)!important;display:flex!important;align-items:center!important;justify-content:center!important;z-index:9999!important;padding:20px!important}.category-selector-content{background:white!important;border-radius:12px!important;padding:30px!important;max-width:500px!important;width:100%!important;box-shadow:0 10px 30px rgba(0,0,0,.3)!important;position:relative!important;animation:modalSlideIn .3s ease-out!important;opacity:1!important;visibility:visible!important}.category-selector-header{justify-content:space-between!important;margin-bottom:25px!important;padding-bottom:15px!important;border-bottom:1px solid #e9ecef!important}.category-selector-close,.category-selector-header{display:flex!important;align-items:center!important}.category-selector-close{background:none!important;border:none!important;font-size:24px!important;color:#6c757d!important;cursor:pointer!important;padding:0!important;width:30px!important;height:30px!important;justify-content:center!important;border-radius:50%!important;transition:all .2s ease!important}.category-selector-close:hover{background:#f8f9fa!important;color:#495057!important}.category-selector-form{gap:20px!important}.category-selector-form,.category-selector-form-group{display:flex!important;flex-direction:column!important}.category-selector-form-group{gap:8px!important}.category-selector-select{padding:12px 16px!important;border:2px solid #e9ecef!important;border-radius:8px!important;font-size:16px!important;background:white!important;transition:border-color .2s ease!important;cursor:pointer!important}.category-selector-select:focus{outline:none!important;border-color:#667eea!important;box-shadow:0 0 0 3px rgba(102,126,234,.1)!important}.category-selector-select:hover{border-color:#ced4da!important}.category-selector-no-categories{background:#f8f9fa!important;border:1px solid #dee2e6!important;border-radius:8px!important;padding:20px!important;text-align:center!important;color:#6c757d!important}.category-selector-actions{display:flex!important;gap:12px!important;justify-content:flex-end!important;margin-top:10px!important}.category-selector-btn{padding:12px 24px!important;border-radius:8px!important;font-size:14px!important;font-weight:600!important;cursor:pointer!important;transition:all .2s ease!important;border:none!important;min-width:100px!important}.chart-manager{margin-top:30px;padding:20px;background:#f8f9fa;border-radius:12px;border:1px solid #e9ecef}.chart-manager-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:25px;padding-bottom:15px;border-bottom:2px solid #e9ecef}.chart-manager-header h2{margin:0;font-size:24px;font-weight:600;color:#2c3e50}.add-chart-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:white;border:none;padding:12px 24px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:8px;box-shadow:0 4px 12px rgba(102,126,234,.3)}.add-chart-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(102,126,234,.4)}.add-chart-btn:active{transform:translateY(0)}.no-charts-message{text-align:center;padding:40px 20px;background:white;border-radius:12px;border:2px dashed #dee2e6;color:#6c757d}.no-charts-message p{margin:8px 0;font-size:16px}.no-charts-message p:first-child{font-weight:600;color:#495057;font-size:18px}.charts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(450px,1fr));grid-gap:20px;gap:20px;align-items:start}@media (max-width:768px){.chart-manager{padding:15px;margin-top:20px}.chart-manager-header{flex-direction:column;gap:15px;align-items:stretch}.chart-manager-header h2{text-align:center;font-size:20px}.add-chart-btn{width:100%;justify-content:center}.charts-grid{grid-template-columns:1fr;gap:15px}.no-charts-message{padding:30px 15px}}@media (max-width:480px){.chart-manager{padding:10px}.chart-manager-header h2{font-size:18px}.add-chart-btn{padding:10px 16px;font-size:13px}}.loading-message{text-align:center;padding:40px 20px;background:white;border-radius:12px;border:2px dashed #dee2e6;color:#6c757d}.loading-message p{margin:8px 0;font-size:16px;font-weight:600;color:#495057}.error-message{text-align:center;padding:40px 20px;background:#fff5f5;border-radius:12px;border:2px solid #fed7d7;color:#c53030}.error-message p{margin:8px 0;font-size:16px;font-weight:600}.retry-btn{background:#e53e3e;color:white;border:none;padding:10px 20px;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;margin-top:15px}.retry-btn:hover{background:#c53030;transform:translateY(-1px)}.investment-portfolio{padding:80px 20px 20px;max-width:1200px;margin:0 auto}.auth-required{text-align:center;padding:40px;background-color:#f8f9fa;border-radius:8px;margin:40px auto;max-width:500px}.auth-required h2{color:#333;margin-bottom:20px}.auth-required p{color:#666;margin-bottom:30px}.auth-required button{padding:10px 20px;background-color:#007bff;color:white;border:none;border-radius:4px;cursor:pointer;font-size:16px}.auth-required button:hover{background-color:#0056b3}.loading{text-align:center;padding:40px;font-size:18px;color:#666}.portfolio-header{margin-bottom:30px}.portfolio-header h1{margin-bottom:20px;color:#333}.portfolio-summary{display:flex;gap:30px;margin-bottom:20px;padding:20px;background-color:#f8f9fa;border-radius:8px}.summary-item{display:flex;flex-direction:column;gap:5px}.summary-item .label{font-size:14px;color:#666}.summary-item .value{font-size:24px;font-weight:700;color:#333}.summary-item .value.positive{color:#28a745}.summary-item .value.negative{color:#dc3545}.portfolio-actions{display:flex;gap:15px;margin-bottom:30px}.btn{padding:10px 20px;border:none;border-radius:4px;cursor:pointer;font-size:14px;font-weight:500;transition:background-color .2s}.btn-primary{background-color:#007bff;color:white}.btn-primary:hover{background-color:#0056b3}.btn-secondary{background-color:#6c757d;color:white}.btn-secondary:hover{background-color:#545b62}.portfolio-assets h2{margin-bottom:20px;color:#333}.empty-portfolio{text-align:center;padding:60px 20px;background-color:#f8f9fa;border-radius:8px}.empty-portfolio p{margin-bottom:20px;color:#666;font-size:16px}.empty-subtitle{font-size:14px;margin-bottom:30px!important;color:#adb5bd!important}.assets-table-container{background:white;border:1px solid #e9ecef;border-radius:8px;overflow:hidden;box-shadow:0 2px 4px rgba(0,0,0,.1)}.assets-table{width:100%;border-collapse:collapse;font-size:14px}.assets-table thead{background-color:#f8f9fa;border-bottom:2px solid #dee2e6}.assets-table th{padding:12px 8px;text-align:left;font-weight:600;color:#495057;font-size:13px;text-transform:uppercase;letter-spacing:.5px}.assets-table tbody tr{border-bottom:1px solid #e9ecef;transition:background-color .2s}.assets-table tbody tr:hover{background-color:#f8f9fa}.assets-table td{padding:12px 8px;vertical-align:top}.asset-name{min-width:150px}.asset-name strong{color:#333;font-size:15px}.asset-name .symbol{color:#6c757d;font-size:12px;font-weight:400}.asset-symbol{min-width:80px;color:#6c757d;font-family:Courier New,monospace}.asset-categories{min-width:200px}.asset-quantity{min-width:100px;text-align:right;font-family:Courier New,monospace}.asset-current-price,.asset-profit-loss,.asset-purchase-price,.asset-total-value{min-width:120px;text-align:right;font-family:Courier New,monospace}.asset-profit-loss{font-weight:700}.asset-profit-loss.positive{color:#28a745}.asset-profit-loss.negative{color:#dc3545}.asset-profit-percent{min-width:80px;text-align:right;font-weight:700;font-family:Courier New,monospace}.asset-profit-percent.positive{color:#28a745}.asset-profit-percent.negative{color:#dc3545}.category-tags{gap:4px}.category-tag{padding:2px 6px;border-radius:10px;font-size:11px;box-shadow:0 1px 2px rgba(0,0,0,.1)}.no-categories{font-size:12px}.modal-overlay{position:fixed!important;top:0!important;left:0!important;right:0!important;bottom:0!important;background-color:rgba(0,0,0,.5)!important;display:flex!important;justify-content:center!important;align-items:center!important;z-index:9999!important}.modal{background:white!important;border-radius:8px!important;max-width:600px!important;width:90%!important;max-height:90vh!important;overflow-y:auto!important;box-shadow:0 4px 20px rgba(0,0,0,.3)!important;position:relative!important;z-index:10000!important}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #e9ecef}.modal-header h2{margin:0;color:#333}.close-btn{background:none;border:none;font-size:24px;cursor:pointer;color:#666;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center}.close-btn:hover{color:#333}.asset-form{padding:20px}.form-group,.form-row{margin-bottom:20px}.form-row{display:grid;grid-template-columns:1fr 1fr;grid-gap:15px;gap:15px}.form-group label{display:block;margin-bottom:5px;font-weight:500;color:#333}.form-group input,.form-group select,.form-group textarea{width:100%;padding:10px;border:1px solid #ddd;border-radius:4px;font-size:14px;transition:border-color .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#007bff}.form-group textarea{resize:vertical;min-height:80px}.form-actions{display:flex;gap:15px;justify-content:flex-end;margin-top:30px;padding-top:20px;border-top:1px solid #e9ecef}.category-manager{padding:20px}.categories-section h3{margin-bottom:15px;color:#333}.categories-list{margin-bottom:30px}.category-item{display:flex;justify-content:space-between;align-items:center;padding:12px;border:1px solid #e9ecef;border-radius:6px;margin-bottom:10px;background-color:#f8f9fa;transition:all .2s ease}.category-item:hover{background-color:#e9ecef;border-color:#dee2e6}.category-info{display:flex;align-items:center;gap:10px}.category-color{width:16px;height:16px;border-radius:50%;border:2px solid #fff;box-shadow:0 1px 3px rgba(0,0,0,.2)}.category-name{font-weight:500;color:#333}.category-name-en{color:#6c757d;font-size:14px}.delete-btn{background-color:#dc3545;color:white;border:none;padding:6px 12px;border-radius:4px;cursor:pointer;font-size:12px;transition:background-color .2s}.delete-btn:hover{background-color:#c82333}.category-with-types-form{border-top:1px solid #e9ecef;padding-top:20px}.category-section,.types-section{margin-bottom:30px}.category-section h4,.types-section h4{margin-bottom:15px;color:#333;font-size:16px;border-bottom:2px solid #007bff;padding-bottom:5px}.types-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.add-type-btn{padding:8px 16px;font-size:13px}.type-field{border:1px solid #e9ecef;border-radius:6px;padding:15px;margin-bottom:15px;background-color:#f8f9fa}.type-field-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.type-field-header h5{margin:0;color:#495057;font-size:14px}.remove-type-btn{background-color:#dc3545;color:white;border:none;border-radius:50%;width:24px;height:24px;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;transition:background-color .2s}.remove-type-btn:hover{background-color:#c82333}@media (max-width:768px){.types-header{flex-direction:column;gap:10px;align-items:stretch}.add-type-btn{width:100%}.type-field{padding:10px}}.category-types-container{border:1px solid #ddd;border-radius:4px;padding:15px;background-color:#f8f9fa}.category-type-row{display:flex;gap:10px;align-items:flex-start;margin-bottom:15px;position:relative}.category-type-row:last-child{margin-bottom:0}.category-type-row .category-type-selector{flex:1 1;margin:0}.remove-category-btn{background-color:#dc3545;color:white;border:none;border-radius:4px;width:30px;height:30px;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:25px}.remove-category-btn:hover{background-color:#c82333}.add-category-btn{background-color:#28a745;color:white;border:none;border-radius:4px;padding:8px 16px;cursor:pointer;font-size:14px;margin-top:10px}.add-category-btn:hover{background-color:#218838}.category-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:5px}.category-tag{display:inline-block;padding:4px 8px;border-radius:12px;font-size:12px;font-weight:500;text-align:center;white-space:nowrap;box-shadow:0 1px 3px rgba(0,0,0,.2);transition:all .2s ease}.category-tag:hover{transform:translateY(-1px);box-shadow:0 2px 6px rgba(0,0,0,.3)}.no-categories{color:#6c757d;font-style:italic;font-size:14px}@media (max-width:768px){.portfolio-summary{gap:15px}.portfolio-actions,.portfolio-summary{flex-direction:column}.assets-table-container{overflow-x:auto}.assets-table{min-width:800px;font-size:12px}.assets-table td,.assets-table th{padding:8px 4px}.asset-name{min-width:120px}.asset-symbol{min-width:60px}.asset-categories{min-width:150px}.asset-quantity{min-width:80px}.asset-current-price,.asset-profit-loss,.asset-purchase-price,.asset-total-value{min-width:100px}.asset-profit-percent{min-width:60px}.category-form .form-row,.form-row{grid-template-columns:1fr}.category-form .form-row{gap:10px}.category-type-row{grid-template-columns:1fr;gap:8px}.modal{width:95%;margin:10px}.category-tags{gap:6px}.category-tag{font-size:11px;padding:3px 6px}}