*{margin:0;padding:0;box-sizing:border-box}body{font-family:Courier New,Courier,monospace;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#1a1a1a;color:#e0e0e0}#app{height:100vh;overflow:hidden}.app{display:flex;flex-direction:column;height:100vh;background:#1a1a1a}.top-bar{display:flex;align-items:center;justify-content:space-between;height:36px;padding:0 16px;background:#1f1f1f;border-bottom:1px solid #333;flex-shrink:0}.top-bar-title{font-size:14px;font-weight:600;color:#ddd;letter-spacing:.5px}.top-bar-actions{display:flex;align-items:center;gap:8px}.new-stock-btn{padding:3px 10px;background:#4caf50;color:#fff;border:none;border-radius:3px;cursor:pointer;font-size:11px;font-weight:500;transition:background .2s ease;flex-shrink:0}.new-stock-btn:hover{background:#45a049}.alloc-label{display:flex;align-items:center;gap:6px;font-size:12px;color:#e0e0e0}.alloc-select{padding:3px 4px;background:#2a2a2a;color:#e0e0e0;border:1px solid #444;border-radius:3px;font-size:12px;cursor:pointer}.alloc-select:hover{border-color:#666}.alloc-select:focus{outline:none;border-color:#2196f3}.alloc-select:disabled{opacity:.5;cursor:default}.stock-count{font-size:11px;color:#888;margin-left:6px}.main-area{display:flex;flex:1;min-height:0;overflow:hidden}.basket-list{width:280px;flex-shrink:0;border-right:1px solid #333;display:flex;flex-direction:column;background:#1a1a1a;overflow-x:hidden;overflow-y:hidden}.basket-header{padding:8px 12px;border-bottom:1px solid #333;display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.basket-header h2{font-size:14px;margin:0;color:#ddd;display:flex;align-items:center;gap:8px;letter-spacing:.5px}.basket-kanji{font-size:18px;color:#4a90e2;font-weight:400;line-height:1}.basket-header-actions{display:flex;gap:4px;align-items:center}.basket-items{flex:1;overflow-y:scroll;overflow-x:hidden;padding:6px;min-height:0;scrollbar-gutter:stable}.basket-items::-webkit-scrollbar{width:8px}.basket-items::-webkit-scrollbar-track{background:#141414;border-left:1px solid #2a2a2a}.basket-items::-webkit-scrollbar-thumb{background:#3a3a3a;border-radius:4px;border:2px solid #141414}.basket-items::-webkit-scrollbar-thumb:hover{background:#4a90e2}.basket-items{scrollbar-width:thin;scrollbar-color:#3a3a3a #141414}.basket-footer{display:flex;gap:4px;align-items:center;padding:8px 12px;border-top:1px solid #333;background:#1f1f1f;flex-shrink:0}.basket-footer .new-stock-btn{flex:1}.empty-basket{flex:1;padding:30px 15px;text-align:center;color:#666;display:flex;flex-direction:column;justify-content:center}.empty-basket p{margin-bottom:8px;font-size:13px}.empty-basket .hint{font-size:11px;color:#555}.basket-item{background:#242424;border:1px solid #333;border-radius:3px;margin-bottom:4px;cursor:pointer;transition:border-color .15s}.basket-item:hover{border-color:#555}.basket-item.selected{border-color:#2196f3;background:#1e2a3a}.basket-item.hidden{opacity:.5}.basket-item-row{display:flex;align-items:center;gap:8px;padding:7px 8px}.stock-color{width:10px;height:10px;border-radius:50%;flex-shrink:0}.stock-name{flex:1;font-size:12px;color:#ddd;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.item-actions{display:flex;gap:2px;flex-shrink:0}.icon-button{background:transparent;border:none;cursor:pointer;font-size:14px;padding:2px 4px;border-radius:3px;transition:background .15s;color:#888;line-height:1}.icon-button:hover{background:#333;color:#ddd}.icon-button.toggle-vis{font-size:15px;color:#66bb6a}.icon-button.toggle-vis:hover{color:#81c784}.icon-button.delete{color:#e57373}.icon-button.delete:hover{background:#f44336;color:#fff}.icon-button.expand{font-size:10px;color:#888;transition:transform .15s}.icon-button.expand.open{transform:rotate(90deg)}.basket-item-accordion{padding:4px 10px 8px;border-top:1px solid #2a2a2a;overflow:hidden}.slider-group{display:flex;align-items:center;gap:6px;margin-bottom:3px;overflow:hidden}.slider-group label{font-size:10px;color:#999;width:60px;flex-shrink:0;text-align:right;white-space:nowrap}.slider-group input[type=range]{flex:1;min-width:0;height:4px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:#444;border-radius:2px;outline:none;cursor:pointer}.slider-group input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:12px;height:12px;border-radius:50%;background:#2196f3;cursor:pointer}.slider-group input[type=range]::-moz-range-thumb{width:12px;height:12px;border-radius:50%;background:#2196f3;cursor:pointer;border:none}.slider-value{font-size:10px;color:#ccc;width:34px;flex-shrink:0;text-align:left}.graph-area{flex:1;min-width:0;display:flex;flex-direction:column;overflow:hidden}.graph-controls{display:flex;gap:15px;padding:6px 15px;align-items:center;flex-wrap:wrap;border-bottom:1px solid #333;background:#1e1e1e;flex-shrink:0}.graph-controls-left{display:flex;gap:10px;align-items:center}.graph-controls-right{display:flex;gap:6px;align-items:center;margin-left:auto}.graph-controls select{padding:4px 8px;border:1px solid #444;border-radius:3px;font-size:12px;background:#2a2a2a;color:#e0e0e0}.graph-controls select:focus{outline:none;border-color:#2196f3}.view-toggle{display:flex;border:1px solid #444;border-radius:4px;overflow:hidden}.toggle-btn{padding:3px 10px;font-size:11px;border:none;background:#2a2a2a;color:#888;cursor:pointer;transition:all .15s ease}.toggle-btn:not(:last-child){border-right:1px solid #444}.toggle-btn:hover{background:#333;color:#ccc}.toggle-btn.active{background:#2196f3;color:#fff}.chart-area{display:flex;flex:1;min-height:0;overflow:hidden;padding:8px 15px 8px 0}.chart-wrapper{flex:1;position:relative;min-height:0;overflow:hidden}.chart-wrapper canvas{width:100%!important;height:100%!important}.alloc-bar-wrap{display:flex;flex-direction:column;align-items:center;flex-shrink:0;border-right:1px solid #444}.alloc-optimize-btn{width:44px;height:28px;background:transparent;border:none;border-bottom:1px solid #444;cursor:pointer;font-size:16px;line-height:1;padding:0;color:inherit;flex-shrink:0;transition:background .12s}.alloc-optimize-btn:hover{background:#ffd70026}.alloc-bar{width:44px;display:flex;flex-direction:column;flex-shrink:0;flex:1}.alloc-segment{display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;overflow:hidden;transition:height .2s ease}.alloc-bar-label{font-size:9px;color:#fff;text-shadow:0 0 3px rgba(0,0,0,.8);white-space:nowrap;pointer-events:none;line-height:1.1;position:absolute;left:0;right:0;top:50%;transform:translateY(-50%);text-align:center;z-index:2}.alloc-adjust{display:none;position:absolute;left:0;right:0;width:100%;height:50%;border:none;background:transparent;cursor:pointer;z-index:1;color:#fffc;font-size:12px;font-weight:700;justify-content:center}.alloc-adjust.alloc-plus{top:0;align-items:flex-start;padding-top:1px}.alloc-adjust.alloc-minus{bottom:0;align-items:flex-end;padding-bottom:1px}.alloc-adjust:hover{background:#0000004d}.alloc-segment.editable:hover .alloc-adjust{display:flex}.alloc-segment.editable:hover{filter:brightness(1.2)}.alloc-segment.editable{cursor:pointer}.chart-overlay-stats{position:absolute;top:30px;left:55px;display:grid;grid-template-columns:auto 72px;column-gap:6px;row-gap:2px;padding:5px 8px;background:#1e1e1ed9;border-radius:4px;border:1px solid #444;z-index:5;pointer-events:none}.stats-panel{height:30%;min-height:180px;flex-shrink:0;border-top:2px solid #333;background:#1e1e1e;display:flex;flex-direction:column;overflow:hidden}.stats-panel-header{display:flex;align-items:center;padding:4px 12px;border-bottom:1px solid #333;flex-shrink:0}.stats-panel-header h3{font-size:12px;color:#999;font-weight:500;margin:0}.stats-panel-content{flex:1;overflow:auto}.trade-table-container{height:100%;overflow:auto;background:#1e1e1e}.trade-table-container::-webkit-scrollbar{width:8px;height:8px}.trade-table-container::-webkit-scrollbar-track{background:#1e1e1e}.trade-table-container::-webkit-scrollbar-thumb{background:#444;border-radius:4px}.trade-table-container::-webkit-scrollbar-thumb:hover{background:#555}.trade-table-container::-webkit-scrollbar-corner{background:#1e1e1e}.trade-table{border-collapse:collapse;font-size:11px;table-layout:fixed}.trade-table thead{position:sticky;top:0;background:#242424;z-index:10}.trade-table th{padding:6px;text-align:right;font-weight:600;color:#ddd;border-bottom:2px solid #333;white-space:nowrap;font-size:11px}.trade-table th:first-child{text-align:left}.trade-table td{padding:5px 6px;border-bottom:1px solid #2a2a2a;white-space:nowrap;font-size:11px;text-align:right;font-variant-numeric:tabular-nums}.trade-table td:first-child{text-align:left}.trade-table tbody tr:hover{background:#242424}.trade-table .positive{color:#4caf50}.trade-table .negative{color:#f44336}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:9999;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal{background:#242424;border:1px solid #444;border-radius:6px;padding:20px 24px;width:380px;max-width:90vw;box-shadow:0 8px 32px #00000080}.modal h2{font-size:16px;color:#ddd;margin-bottom:16px}.modal-field{margin-bottom:12px}.modal-field .error-message{margin:6px 0 0;padding:6px 8px;font-size:11px}.modal-validation-errors{margin:0 0 6px}.modal-field label{display:block;font-size:11px;font-weight:500;color:#999;margin-bottom:4px}.modal-field input,.modal-field select{width:100%;padding:6px 10px;border:1px solid #444;border-radius:3px;font-size:12px;background:#2a2a2a;color:#e0e0e0}.modal-field input:focus,.modal-field select:focus{outline:none;border-color:#2196f3}.modal-row{display:flex;gap:10px}.modal-row .modal-field{flex:1}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:18px}.modal-btn{padding:7px 18px;border:none;border-radius:3px;cursor:pointer;font-size:12px;font-weight:500;transition:background .2s ease}.modal-btn.primary{background:#4caf50;color:#fff}.modal-btn.primary:hover{background:#45a049}.modal-btn.primary:disabled{opacity:.5;cursor:not-allowed}.modal-btn.secondary{background:#333;color:#ccc;border:1px solid #555}.modal-btn.secondary:hover{background:#444}.fetch-modal{width:460px;height:360px;padding:0;display:flex;flex-direction:column;overflow:hidden}.fetch-modal .fetch-titlebar{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:#1e1e1e;border-bottom:1px solid #444;flex-shrink:0}.fetch-modal .fetch-titlebar h2{margin:0;font-size:13px;font-weight:500;color:#ccc}.fetch-modal .fetch-titlebar .fetch-progress{display:flex;align-items:center;gap:8px;font-size:11px;color:#888;margin:0}.fetch-cached{color:#666;font-size:11px}.fetch-modal .fetch-body{display:flex;flex-direction:column;flex:1;min-height:0;padding:8px 10px}.fetch-log{flex:1;min-height:0;overflow-y:auto;background:#1a1a1a;border:1px solid #333;border-radius:3px;padding:6px 8px;font-size:11px;line-height:1.6}.fetch-modal .modal-actions{margin-top:8px;flex-shrink:0}.fetch-log::-webkit-scrollbar{width:6px}.fetch-log::-webkit-scrollbar-track{background:#1a1a1a}.fetch-log::-webkit-scrollbar-thumb{background:#444;border-radius:3px}.fetch-log-entry{display:flex;gap:6px;white-space:nowrap}.fetch-icon{width:14px;flex-shrink:0;text-align:center}.fetch-year{width:36px;flex-shrink:0;color:#888}.fetch-msg{overflow:hidden;text-overflow:ellipsis}.fetch-ok,.fetch-ok .fetch-icon{color:#4caf50}.fetch-nodata{color:#888}.fetch-nodata .fetch-icon{color:#ffc107}.fetch-error,.fetch-error .fetch-icon{color:#f44336}.fetch-info{color:#999}.fetch-info .fetch-icon{color:#2196f3}.searchable-dropdown{position:relative}.searchable-dropdown input{width:100%;padding:6px 10px;border:1px solid #444;border-radius:3px;font-size:12px;background:#2a2a2a;color:#e0e0e0}.searchable-dropdown input:focus{outline:none;border-color:#2196f3}.dropdown-options{position:absolute;top:100%;left:0;right:0;max-height:250px;overflow-y:auto;background:#2a2a2a;border:1px solid #444;border-top:none;border-radius:0 0 3px 3px;z-index:10000;box-shadow:0 4px 8px #0000004d}.dropdown-option{padding:5px 10px;cursor:pointer;display:flex;justify-content:space-between;gap:10px;font-size:11px;border-bottom:1px solid #333}.dropdown-option:hover,.dropdown-option.highlighted{background:#333}.option-symbol{font-weight:600;color:#2196f3;flex-shrink:0}.option-name{color:#999;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.summary-label{font-size:11px;color:#999;font-weight:500;text-align:right;white-space:nowrap}.summary-value{font-size:12px;font-weight:600;color:#e0e0e0;white-space:nowrap;text-align:right;font-variant-numeric:tabular-nums}.summary-value.positive{color:#4caf50}.summary-value.negative{color:#f44336}.positive{color:#4caf50}.negative{color:#f44336}.empty-state{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;color:#666;font-size:14px;pointer-events:none;z-index:1}.loading-spinner{display:flex;align-items:center;justify-content:center;height:100%;font-size:14px;color:#999}.error-message{padding:10px 12px;margin:10px;background:#3a1f1f;color:#ff6b6b;border-radius:3px;border-left:4px solid #F44336;font-size:12px}@media(max-width:768px){.main-area{flex-direction:column}.basket-list{width:100%;height:30%;border-right:none;border-bottom:1px solid #333}.graph-area{height:70%}}.optimize-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;display:flex;align-items:center;justify-content:center;z-index:9999}.optimize-modal{background:#1f2429;border:1px solid #3a4148;border-radius:8px;padding:32px 48px;text-align:center;color:#e0e0e0;box-shadow:0 8px 32px #00000080}.optimize-spinner{font-size:48px;animation:optimize-pulse 1s ease-in-out infinite}.optimize-title{font-size:18px;font-weight:500;margin-top:12px}.optimize-sub{font-size:13px;color:#999;margin-top:6px}@keyframes optimize-pulse{0%,to{opacity:.4;transform:scale(1)}50%{opacity:1;transform:scale(1.15)}}.help-button{width:26px;height:26px;border-radius:50%;border:1px solid #555;background:#2a2a2a;color:#ccc;font-size:14px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;padding:0}.help-button:hover{background:#3a3a3a;border-color:#4a90e2;color:#fff}.help-modal{width:760px;max-width:95vw;max-height:85vh;padding:0;display:flex;flex-direction:column}.help-header{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;border-bottom:1px solid #444}.help-header h2{margin:0}.help-tabs{display:flex;flex-wrap:wrap;gap:0;padding:0 20px;border-bottom:1px solid #444;background:#1f1f1f}.help-tab{background:transparent;color:#aaa;border:none;padding:10px 14px;font-size:13px;cursor:pointer;border-bottom:2px solid transparent;transition:all .15s}.help-tab:hover{color:#fff}.help-tab.active{color:#4a90e2;border-bottom-color:#4a90e2}.help-body{padding:20px 24px;overflow-y:auto;flex:1;color:#ddd;line-height:1.55;font-size:14px}.help-section h3{color:#fff;margin-top:18px;margin-bottom:8px;font-size:15px}.help-section h3:first-child{margin-top:0}.help-section p{margin:6px 0 10px}.help-section dl{margin:6px 0 12px}.help-section dt{color:#4a90e2;font-weight:600;margin-top:8px}.help-section dt code{color:#7ab8ff;font-weight:400;font-size:12px;margin-left:4px}.help-section dd{margin:2px 0 0 16px;color:#bbb}.help-section ol,.help-section ul{margin:6px 0 12px 20px;padding:0}.help-section li{margin:4px 0}.help-section code{background:#1a1a1a;border:1px solid #333;border-radius:3px;padding:1px 5px;font-size:12px;color:#e0a060}.help-section em{color:#fff;font-style:normal;font-weight:600}.help-icon{display:inline-block;padding:0 2px;color:#aaa}.help-note{background:#1a1a1a;border-left:3px solid #4a90e2;padding:8px 12px;margin:10px 0;color:#aaa;font-size:13px}
