.react-grid-layout{position:relative;transition:height .2s ease}.react-grid-item{transition:all .2s ease;transition-property:left,top,width,height}.react-grid-item img{pointer-events:none;-webkit-user-select:none;user-select:none}.react-grid-item.cssTransforms{transition-property:transform,width,height}.react-grid-item.resizing{transition:none;z-index:1;will-change:width,height}.react-grid-item.react-draggable-dragging{transition:none;z-index:3;will-change:transform}.react-grid-item.dropping{visibility:hidden}.react-grid-item.react-grid-placeholder{background:red;opacity:.2;transition-duration:.1s;z-index:2;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;-o-user-select:none;user-select:none}.react-grid-item.react-grid-placeholder.placeholder-resizing{transition:none}.react-grid-item>.react-resizable-handle{position:absolute;width:20px;height:20px}.react-grid-item>.react-resizable-handle:after{content:"";position:absolute;right:3px;bottom:3px;width:5px;height:5px;border-right:2px solid rgba(0,0,0,.4);border-bottom:2px solid rgba(0,0,0,.4)}.react-resizable-hide>.react-resizable-handle{display:none}.react-grid-item>.react-resizable-handle.react-resizable-handle-sw{bottom:0;left:0;cursor:sw-resize;transform:rotate(90deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-se{bottom:0;right:0;cursor:se-resize}.react-grid-item>.react-resizable-handle.react-resizable-handle-nw{top:0;left:0;cursor:nw-resize;transform:rotate(180deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-ne{top:0;right:0;cursor:ne-resize;transform:rotate(270deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-w,.react-grid-item>.react-resizable-handle.react-resizable-handle-e{top:50%;margin-top:-10px;cursor:ew-resize}.react-grid-item>.react-resizable-handle.react-resizable-handle-w{left:0;transform:rotate(135deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-e{right:0;transform:rotate(315deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-n,.react-grid-item>.react-resizable-handle.react-resizable-handle-s{left:50%;margin-left:-10px;cursor:ns-resize}.react-grid-item>.react-resizable-handle.react-resizable-handle-n{top:0;transform:rotate(225deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-s{bottom:0;transform:rotate(45deg)}.react-resizable{position:relative}.react-resizable-handle{position:absolute;width:20px;height:20px;background-repeat:no-repeat;background-origin:content-box;box-sizing:border-box;background-image:url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCA2IDYiIHN0eWxlPSJiYWNrZ3JvdW5kLWNvbG9yOiNmZmZmZmYwMCIgeD0iMHB4IiB5PSIwcHgiIHdpZHRoPSI2cHgiIGhlaWdodD0iNnB4Ij48ZyBvcGFjaXR5PSIwLjMwMiI+PHBhdGggZD0iTSA2IDYgTCAwIDYgTCAwIDQuMiBMIDQgNC4yIEwgNC4yIDQuMiBMIDQuMiAwIEwgNiAwIEwgNiA2IEwgNiA2IFoiIGZpbGw9IiMwMDAwMDAiLz48L2c+PC9zdmc+);background-position:bottom right;padding:0 3px 3px 0}.react-resizable-handle-sw{bottom:0;left:0;cursor:sw-resize;transform:rotate(90deg)}.react-resizable-handle-se{bottom:0;right:0;cursor:se-resize}.react-resizable-handle-nw{top:0;left:0;cursor:nw-resize;transform:rotate(180deg)}.react-resizable-handle-ne{top:0;right:0;cursor:ne-resize;transform:rotate(270deg)}.react-resizable-handle-w,.react-resizable-handle-e{top:50%;margin-top:-10px;cursor:ew-resize}.react-resizable-handle-w{left:0;transform:rotate(135deg)}.react-resizable-handle-e{right:0;transform:rotate(315deg)}.react-resizable-handle-n,.react-resizable-handle-s{left:50%;margin-left:-10px;cursor:ns-resize}.react-resizable-handle-n{top:0;transform:rotate(225deg)}.react-resizable-handle-s{bottom:0;transform:rotate(45deg)}:root{--bg-primary: #0a0e17;--bg-secondary: #111827;--bg-tertiary: #1f2937;--bg-card: rgba(17, 24, 39, .85);--bg-glass: rgba(255, 255, 255, .05);--text-primary: #f9fafb;--text-secondary: #9ca3af;--text-muted: #6b7280;--accent-primary: #3b82f6;--accent-secondary: #8b5cf6;--accent-gradient: linear-gradient(135deg, #3b82f6, #8b5cf6);--positive: #10b981;--negative: #ef4444;--warning: #f59e0b;--sector-fishery: #0ea5e9;--sector-mining: #78716c;--sector-construction: #f97316;--sector-foods: #84cc16;--sector-textiles: #ec4899;--sector-pulp: #a3a3a3;--sector-chemicals: #6366f1;--sector-pharma: #14b8a6;--sector-oil: #1e3a5f;--sector-rubber: #525252;--sector-glass: #06b6d4;--sector-steel: #71717a;--sector-nonferrous: #eab308;--sector-metal: #a1a1aa;--sector-machinery: #3b82f6;--sector-electric: #8b5cf6;--sector-transport-equip: #ef4444;--sector-precision: #22d3ee;--sector-other-products: #a855f7;--sector-power: #fbbf24;--sector-gas: #f472b6;--sector-land-transport: #16a34a;--sector-marine: #0284c7;--sector-air: #7c3aed;--sector-warehouse: #d97706;--sector-telecom: #2563eb;--sector-wholesale: #059669;--sector-retail: #db2777;--sector-banks: #0f766e;--sector-securities: #7c2d12;--sector-insurance: #166534;--sector-other-finance: #4f46e5;--sector-realestate: #c2410c;--sector-services: #9333ea;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .4), 0 2px 4px -2px rgba(0, 0, 0, .3);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .5), 0 4px 6px -4px rgba(0, 0, 0, .4);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .5), 0 8px 10px -6px rgba(0, 0, 0, .4);--shadow-glow: 0 0 20px rgba(59, 130, 246, .3);--font-family: "Inter", "Noto Sans JP", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .35s ease;--z-base: 0;--z-above: 10;--z-header: 100;--z-modal-backdrop: 500;--z-modal: 1000}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-family);background:var(--bg-primary);color:var(--text-primary);line-height:1.6;min-height:100vh;overflow:hidden}#root{min-height:100vh;display:flex;flex-direction:column}.app-container{display:flex;flex-direction:column;height:100vh;overflow:hidden}.header{background:var(--bg-secondary);border-bottom:1px solid rgba(255,255,255,.1);padding:var(--space-sm) var(--space-lg);display:flex;align-items:center;gap:var(--space-lg);z-index:var(--z-header);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.header__logo{display:flex;align-items:center;gap:var(--space-sm)}.header__logo-icon{width:32px;height:32px;background:var(--accent-gradient);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.875rem}.header__logo-text{font-size:1.125rem;font-weight:600;background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.header__search{flex:1;max-width:400px}.header__filters{display:flex;gap:var(--space-sm)}.header__stats{margin-left:auto;display:flex;align-items:center;gap:var(--space-md);color:var(--text-secondary);font-size:.875rem}.search-bar{position:relative}.search-bar__input{width:100%;padding:var(--space-sm) var(--space-md);padding-left:2.5rem;background:var(--bg-tertiary);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-lg);color:var(--text-primary);font-size:.875rem;transition:all var(--transition-fast)}.search-bar__input::placeholder{color:var(--text-muted)}.search-bar__input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #3b82f633}.search-bar__icon{position:absolute;left:var(--space-sm);top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.search-bar__results{position:absolute;top:calc(100% + var(--space-xs));left:0;right:0;background:var(--bg-secondary);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-md);max-height:300px;overflow-y:auto;z-index:var(--z-above);box-shadow:var(--shadow-lg)}.search-bar__result{padding:var(--space-sm) var(--space-md);cursor:pointer;display:flex;align-items:center;gap:var(--space-sm);transition:background var(--transition-fast)}.search-bar__result:hover{background:var(--bg-tertiary)}.search-bar__result-code{font-family:var(--font-mono);color:var(--accent-primary);font-size:.875rem}.search-bar__result-name{color:var(--text-primary)}.search-bar__result-sector{margin-left:auto;color:var(--text-muted);font-size:.75rem}.filter-btn{padding:var(--space-xs) var(--space-md);background:var(--bg-tertiary);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-full);color:var(--text-secondary);font-size:.8125rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.filter-btn:hover{background:var(--bg-glass);border-color:#fff3}.filter-btn--active{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff}.filter-btn--prime{--filter-color: #3b82f6}.filter-btn--standard{--filter-color: #10b981}.filter-btn--growth{--filter-color: #f59e0b}.filter-btn--active.filter-btn--prime,.filter-btn--active.filter-btn--standard,.filter-btn--active.filter-btn--growth{background:var(--filter-color);border-color:var(--filter-color)}.chaos-map{flex:1;overflow:auto;background:radial-gradient(circle at 20% 30%,rgba(59,130,246,.08) 0%,transparent 50%),radial-gradient(circle at 80% 70%,rgba(139,92,246,.08) 0%,transparent 50%),var(--bg-primary)}.chaos-map__content{min-width:2400px;padding:var(--space-lg)}.react-grid-item{transition:all .2s ease}.react-grid-item.react-grid-placeholder{background:var(--accent-primary);opacity:.2;border-radius:var(--radius-xl)}.react-grid-item>.react-resizable-handle{position:absolute;opacity:0}.react-grid-item>.react-resizable-handle-se,.react-grid-item>.react-resizable-handle-sw,.react-grid-item>.react-resizable-handle-ne,.react-grid-item>.react-resizable-handle-nw{width:30px;height:30px}.react-grid-item>.react-resizable-handle-se{right:0;bottom:0;cursor:se-resize}.react-grid-item>.react-resizable-handle-sw{left:0;bottom:0;cursor:sw-resize}.react-grid-item>.react-resizable-handle-ne{right:0;top:0;cursor:ne-resize}.react-grid-item>.react-resizable-handle-nw{left:0;top:0;cursor:nw-resize}.react-grid-item>.react-resizable-handle-n,.react-grid-item>.react-resizable-handle-s{left:30px;right:30px;height:20px;cursor:ns-resize}.react-grid-item>.react-resizable-handle-n{top:0}.react-grid-item>.react-resizable-handle-s{bottom:0}.react-grid-item>.react-resizable-handle-e,.react-grid-item>.react-resizable-handle-w{top:30px;bottom:30px;width:20px;cursor:ew-resize}.react-grid-item>.react-resizable-handle-e{right:0}.react-grid-item>.react-resizable-handle-w{left:0}.tag-filter{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-xs) var(--space-md);background:var(--bg-secondary);border-radius:var(--radius-full);max-width:600px}.tag-filter__label{font-size:.75rem;color:var(--text-secondary);white-space:nowrap;flex-shrink:0}.tag-filter__tags{display:flex;gap:4px;overflow-x:auto;padding:2px 0;scrollbar-width:thin}.tag-filter__tags::-webkit-scrollbar{height:4px}.tag-filter__tags::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:2px}.tag-filter__tag{padding:3px 8px;font-size:.625rem;font-weight:500;background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid transparent;border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;flex-shrink:0}.tag-filter__tag:hover{background:var(--bg-glass);color:var(--text-primary)}.tag-filter__tag--active{background:#3b82f633;color:var(--accent-primary);border-color:var(--accent-primary)}.tag-filter__clear{padding:3px 8px;font-size:.625rem;font-weight:500;background:#ef444433;color:#ef4444;border:none;border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;flex-shrink:0}.tag-filter__clear:hover{background:#ef44444d}.sector-filter{position:relative}.sector-filter__toggle{display:flex;align-items:center;gap:var(--space-xs);padding:var(--space-xs) var(--space-md);background:var(--bg-tertiary);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-full);color:var(--text-secondary);font-size:.8125rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.sector-filter__toggle:hover{background:var(--bg-glass);border-color:#fff3}.sector-filter__icon{font-size:1rem}.sector-filter__count{font-size:.6875rem;background:#3b82f633;color:var(--accent-primary);padding:2px 6px;border-radius:var(--radius-full)}.sector-filter__arrow{font-size:.625rem;color:var(--text-muted)}.sector-filter__dropdown{position:absolute;top:calc(100% + var(--space-xs));right:0;background:var(--bg-secondary);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);z-index:var(--z-modal-backdrop);min-width:280px;max-height:400px;overflow:hidden;display:flex;flex-direction:column}.sector-filter__actions{display:flex;gap:var(--space-xs);padding:var(--space-sm);border-bottom:1px solid rgba(255,255,255,.08)}.sector-filter__action-btn{flex:1;padding:var(--space-xs) var(--space-sm);background:var(--bg-tertiary);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-md);color:var(--text-secondary);font-size:.75rem;cursor:pointer;transition:all var(--transition-fast)}.sector-filter__action-btn:hover{background:var(--accent-primary);color:#fff}.sector-filter__list{padding:var(--space-sm);overflow-y:auto;display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-xs)}.sector-filter__item{display:flex;align-items:center;gap:var(--space-xs);padding:var(--space-xs) var(--space-sm);background:var(--bg-tertiary);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.sector-filter__item:hover{background:var(--bg-glass)}.sector-filter__item input[type=checkbox]{width:14px;height:14px;accent-color:var(--accent-primary)}.sector-filter__indicator{width:8px;height:8px;border-radius:50%;flex-shrink:0}.sector-filter__name{font-size:.6875rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sector-block{background:linear-gradient(135deg,color-mix(in srgb,var(--sector-color) 15%,var(--bg-card)) 0%,var(--bg-card) 60%,color-mix(in srgb,var(--sector-color) 8%,var(--bg-card)) 100%);border:1px solid color-mix(in srgb,var(--sector-color) 30%,transparent);border-radius:var(--radius-xl);padding:var(--space-md);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:all var(--transition-normal);width:100%;height:100%;overflow:auto;box-shadow:0 4px 20px color-mix(in srgb,var(--sector-color) 10%,transparent),inset 0 1px color-mix(in srgb,var(--sector-color) 20%,transparent)}.sector-block--small{width:220px}.sector-block--medium{width:300px}.sector-block--large{width:400px}.sector-block:hover{border-color:#ffffff26;box-shadow:var(--shadow-lg)}.sector-block__header{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-md);padding-bottom:var(--space-sm);border-bottom:1px solid rgba(255,255,255,.08);cursor:grab}.sector-block__header:active{cursor:grabbing}.sector-block__drag-handle{color:var(--text-muted);font-size:.875rem;opacity:.5;transition:opacity var(--transition-fast)}.sector-block:hover .sector-block__drag-handle{opacity:1}.sector-block__indicator{width:4px;height:24px;border-radius:var(--radius-full);background:var(--sector-color, var(--accent-primary))}.sector-block__title{font-size:.875rem;font-weight:600;color:var(--text-primary)}.sector-block__count{margin-left:auto;font-size:.75rem;color:var(--text-muted);background:var(--bg-tertiary);padding:2px 8px;border-radius:var(--radius-full)}.sector-block__markets{display:flex;flex-direction:column;gap:var(--space-sm)}.sector-block__market-group{display:flex;flex-direction:column;gap:var(--space-xs)}.sector-block__market-label{font-size:.625rem;font-weight:600;color:var(--market-color);padding:2px 6px;border-left:2px solid var(--market-color);background:#ffffff08;border-radius:0 var(--radius-sm) var(--radius-sm) 0}.sector-block__grid{display:flex;flex-wrap:wrap;gap:var(--space-xs);align-items:flex-start}.stock-tile{background:var(--bg-tertiary);border:1px solid rgba(255,255,255,.05);border-left:3px solid hsl(var(--tile-hue, 200),65%,55%);border-radius:var(--radius-md);padding:var(--space-xs) var(--space-sm);cursor:pointer;transition:all var(--transition-fast);text-align:left;width:75px;flex-shrink:0;display:flex;flex-direction:column;justify-content:flex-start;gap:2px}.stock-tile:hover{background:var(--bg-glass);border-color:var(--accent-primary);border-left-color:var(--accent-primary);transform:translateY(-2px);box-shadow:var(--shadow-glow)}.stock-tile--large{width:100px;padding:var(--space-sm)}.stock-tile--large .stock-tile__name{font-size:.8125rem}.stock-tile__code{font-family:var(--font-mono);font-size:.625rem;color:var(--accent-primary);font-weight:600;opacity:.8}.stock-tile__name{font-size:.6875rem;font-weight:500;color:var(--text-primary);line-height:1.25;word-break:break-word}.stock-tile--highlighted{animation:pulse-highlight 2s ease-in-out infinite;border-color:var(--accent-primary);box-shadow:var(--shadow-glow)}@keyframes pulse-highlight{0%,to{box-shadow:0 0 #3b82f666}50%{box-shadow:0 0 20px 5px #3b82f64d}}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:var(--z-modal-backdrop);display:flex;align-items:center;justify-content:center;animation:fadeIn var(--transition-fast)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--bg-secondary);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-xl);padding:var(--space-xl);width:90%;max-width:480px;z-index:var(--z-modal);box-shadow:var(--shadow-xl);animation:slideUp var(--transition-normal)}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal__header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--space-lg)}.modal__title{font-size:1.25rem;font-weight:600;color:var(--text-primary)}.modal__code{font-family:var(--font-mono);color:var(--accent-primary);font-size:.875rem;margin-left:var(--space-sm)}.modal__close{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:var(--space-xs);border-radius:var(--radius-sm);transition:all var(--transition-fast);font-size:1.25rem;line-height:1}.modal__close:hover{background:var(--bg-tertiary);color:var(--text-primary)}.modal__tags{display:flex;gap:var(--space-sm);margin-bottom:var(--space-lg)}.modal__tag{font-size:.75rem;padding:2px 10px;border-radius:var(--radius-full);background:var(--bg-tertiary);color:var(--text-secondary)}.modal__tag--prime{background:#3b82f633;color:#60a5fa}.modal__tag--standard{background:#10b98133;color:#34d399}.modal__tag--growth{background:#f59e0b33;color:#fbbf24}.modal__section{margin-bottom:var(--space-lg)}.modal__section:last-child{margin-bottom:0}.modal__section-title{font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-sm);display:flex;align-items:center;gap:var(--space-xs)}.modal__links{display:flex;flex-wrap:wrap;gap:var(--space-sm)}.modal__link{display:inline-flex;align-items:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-md);background:var(--bg-tertiary);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-md);color:var(--text-primary);text-decoration:none;font-size:.8125rem;font-weight:500;transition:all var(--transition-fast)}.modal__link:hover{background:var(--accent-primary);border-color:var(--accent-primary);transform:translateY(-1px)}.modal__link-icon{font-size:1rem}.zoom-controls{position:fixed;bottom:var(--space-lg);right:var(--space-lg);display:flex;flex-direction:column;gap:var(--space-xs);z-index:var(--z-above)}.zoom-btn{width:40px;height:40px;background:var(--bg-secondary);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.25rem;transition:all var(--transition-fast)}.zoom-btn:hover{background:var(--bg-tertiary);border-color:var(--accent-primary)}.zoom-btn:active{transform:scale(.95)}.market-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:var(--radius-full);font-size:.6875rem;font-weight:500}.market-badge--prime{background:#3b82f633;color:#60a5fa}.market-badge--standard{background:#10b98133;color:#34d399}.market-badge--growth{background:#f59e0b33;color:#fbbf24}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
