*{box-sizing:border-box;margin:0;padding:0}html,body{width:100%;height:100%}body{color:#333;background:#fafafa;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}#root{width:100%;height:100%}.app-container{flex-direction:column;width:100%;height:100%;display:flex;position:relative}.header{z-index:20;background:#fff;border-bottom:1px solid #ddd;flex-wrap:wrap;align-items:center;gap:.5rem;width:100%;max-width:100%;padding:.25rem .5rem;display:flex;position:relative;overflow:visible;box-shadow:0 1px 2px #0000000d}.header h1{flex-wrap:wrap;flex:1;align-items:center;gap:.5rem;min-width:0;margin:0;font-size:1em;font-weight:600;display:flex}.header-select{cursor:pointer;border:1px solid #ddd;border-radius:3px;height:28px;padding:.25rem .5rem;font-size:.75rem}.header p{color:#666;margin:0;font-size:.65rem;display:none}.controls{flex-wrap:wrap;order:3;align-items:center;gap:.4rem;width:100%;margin:0;display:flex}.header-top{align-items:center;gap:.5rem;width:100%;display:flex}.controls label{white-space:nowrap;font-size:.75rem;font-weight:500}.controls select{cursor:pointer;border:1px solid #ddd;border-radius:3px;height:28px;padding:.25rem .5rem;font-size:.75rem}.controls button{color:#fff;cursor:pointer;background:#1da1f2;border:none;border-radius:3px;height:28px;padding:.25rem .75rem;font-size:.75rem;font-weight:500;transition:background .2s}.controls button:hover{background:#1a8cd8}.controls button:disabled{cursor:not-allowed;background:#ccc}.search-form{flex:1;gap:.3rem;min-width:200px;display:flex}.search-input{border:1px solid #ddd;border-radius:3px;flex:1;height:28px;padding:.25rem .5rem;font-size:.75rem}.search-btn{color:#fff;cursor:pointer;white-space:nowrap;background:#1da1f2;border:none;border-radius:3px;height:28px;padding:.25rem .75rem;font-size:.75rem;font-weight:500;transition:background .2s}.search-btn:hover{background:#1a8cd8}.search-btn:disabled{cursor:not-allowed;background:#ccc}.content{width:100%;height:100%;position:fixed;top:0;left:0;overflow:hidden}.graph-container{width:100%;height:100%;position:relative}#sigma-container{background:#0a1628;width:100%;height:100%}.crosshair{pointer-events:none;z-index:5;width:60px;height:60px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.crosshair:before{content:"";background:#f5d963cc;width:100%;height:1px;position:absolute;top:50%;left:0;transform:translateY(-50%)}.crosshair:after{content:"";background:#f5d963cc;width:1px;height:100%;position:absolute;top:0;left:50%;transform:translate(-50%)}.zoom-controls{z-index:10;flex-direction:column;gap:5px;display:flex;position:absolute;bottom:10px;right:10px}.zoom-btn,.reset-btn{cursor:pointer;color:#f5d963;background:#1a2f4d;border:1px solid #f5d963;border-radius:4px;width:35px;height:35px;padding:0;font-size:1.2rem;font-weight:700;transition:all .2s;box-shadow:0 2px 4px #0000004d}.zoom-btn:hover,.reset-btn:hover{background:#2a4f6d;border-color:#f5d963}.zoom-btn:active,.reset-btn:active{color:#0a1628;background:#f5d963}.user-panel{z-index:100;-webkit-user-select:none;user-select:none;pointer-events:auto;background:#fff;border:1px solid #ddd;border-radius:4px;width:400px;max-height:calc(100vh - 60px);padding:.6rem;position:fixed;overflow-y:auto;box-shadow:0 2px 8px #0000001a}.avatar-container{text-align:center;margin-bottom:.5rem}.user-avatar{object-fit:cover;background:#fff;border:2px solid #1da1f2;border-radius:50%;width:60px;height:60px;display:block}.info-item{margin-bottom:.25rem;font-size:.75rem;line-height:1.4}.info-item .display-name{color:#333;font-size:.8rem;font-weight:600}.info-label{color:#666;font-size:.75rem;font-weight:500}.info-value{color:#333;font-size:.75rem}.stats-row{color:#333;border-top:1px solid #eee;flex-direction:column;gap:.15rem;margin-top:.4rem;padding-top:.4rem;font-size:.7rem;display:flex}.stats-row span{justify-content:space-between;display:flex}.loading{color:#666;justify-content:center;align-items:center;width:100%;height:100%;font-size:1rem;display:flex}.error{color:#c62828;z-index:1000;white-space:normal;word-break:break-word;cursor:pointer;background:#ffebee;border:1px solid #ef5350;border-radius:4px;max-width:90%;margin-top:.25rem;padding:.75rem 1rem;font-size:.75rem;position:absolute;top:100%;left:50%;transform:translate(-50%);box-shadow:0 2px 8px #00000026}.profile-link{color:#1da1f2;font-weight:500;text-decoration:none;transition:color .2s;display:inline}.profile-link:hover{color:#1a8cd8;text-decoration:underline}.info-btn{color:#666;cursor:pointer;background:#f5f5f5;border:1px solid #ddd;border-radius:50%;width:24px;height:24px;margin-left:.3rem;padding:0;font-size:.75rem;font-weight:700;transition:all .2s}.info-btn:hover{color:#333;background:#e0e0e0;border-color:#999}.stats-btn{color:#fff;cursor:pointer;white-space:nowrap;background:#ff6b4a;border:1px solid #ff6b4a;border-radius:4px;margin-left:.3rem;padding:.3rem .8rem;font-size:.8rem;font-weight:600;transition:all .2s}.stats-btn:hover{background:#ff5733;border-color:#ff5733}.modal-overlay{z-index:999;background:#00000080;width:100%;height:100%;position:fixed;top:0;left:0}.info-modal{z-index:1001;background:#fff;border-radius:8px;flex-direction:column;width:90%;max-width:500px;max-height:80vh;display:flex;position:fixed;top:0;left:50%;transform:translate(-50%);box-shadow:0 4px 16px #0003}.info-modal-header{background:#f9f9f9;border-bottom:1px solid #ddd;justify-content:space-between;align-items:center;padding:1rem;display:flex}.info-modal-header h2{margin:0;font-size:1rem;font-weight:600}.close-btn{color:#999;cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;width:24px;height:24px;padding:0;font-size:1.5rem;transition:color .2s;display:flex}.close-btn:hover{color:#333}.info-modal-content{color:#333;flex:1;padding:1rem 1rem .5rem;font-size:.85rem;line-height:1.6;overflow-y:auto}.info-modal-content p{margin:.25rem 0}.info-modal-content strong{color:#1da1f2}.info-modal-footer{text-align:center;background:#f9f9f9;border-top:1px solid #eee;flex-shrink:0;padding:.5rem 1rem 1rem;font-size:.85rem}.info-modal-footer p{margin:0}.stats-modal{z-index:1001;background:#fff;border:1px solid #ddd;border-radius:4px;flex-direction:column;width:280px;max-height:calc(100vh - 60px);display:flex;position:fixed;right:10px;box-shadow:0 2px 8px #0000001a}.stats-modal-header{background:#f9f9f9;border-bottom:1px solid #eee;flex-wrap:wrap;justify-content:space-between;align-items:center;padding:0;display:flex}.stats-modal-tabs{border-bottom:1px solid #eee;flex:1;gap:0;display:flex}.stats-tab{color:#666;cursor:pointer;text-align:center;background:#f9f9f9;border:none;border-right:1px solid #eee;flex:1;padding:.6rem .1rem;font-size:.75rem;font-weight:500;transition:all .2s}.stats-tab:last-child{border-right:none}.stats-tab.active{color:#1da1f2;background:#fff;border-bottom:2px solid #1da1f2;margin-bottom:-1px}.stats-modal-header h2{margin:0;font-size:.85rem;font-weight:600}.stats-modal-content{flex:1;padding:.4rem;overflow-y:auto}.ranking-card{background:#fff;border:2px solid #eee;border-radius:3px;margin-bottom:.3rem;margin-right:.7rem;padding:.4rem;font-size:.75rem;overflow:hidden}.ranking-card.selected{border-color:#1da1f2}.ranking-badge{color:#1da1f2;margin-bottom:.3rem;font-size:.7rem;font-weight:700}.ranking-card-header{align-items:center;gap:.4rem;margin-bottom:.3rem;display:flex}.ranking-card-avatar{object-fit:cover;border-radius:50%;flex-shrink:0;width:45px;height:45px}.ranking-card-title{color:#333;word-break:break-word;flex:1;font-size:.75rem;font-weight:600;line-height:1.3}.ranking-card-stats{color:#333;border-top:1px solid #eee;flex-wrap:wrap;gap:.6rem;padding-top:.3rem;font-size:.65rem;display:flex}.ranking-card-stats span{gap:.2rem;display:flex}.ranking-card-stats span:first-child strong{color:#e74c3c;font-weight:700}.stats-info-container{flex-direction:column;gap:.4rem;padding:.4rem;display:flex}.stats-info-item{color:#333;background:#f5f5f5;border:1px solid #ddd;border-radius:3px;flex-direction:column;gap:.1rem;padding:.3rem .5rem;font-size:.7rem;display:flex}.stats-info-label{color:#666;font-size:.65rem;font-weight:500}.stats-info-value{color:#1da1f2;word-break:break-word;font-size:.75rem;font-weight:600}.hashtags-filter-container{flex-direction:column;gap:.5rem;padding:.5rem;display:flex}.filter-status{background:#e3f2fd;border-radius:3px;justify-content:space-between;align-items:center;margin-bottom:.3rem;padding:.5rem;font-size:.7rem;display:flex}.filter-active-label{color:#1976d2;flex:1;font-weight:600}.filter-clear-btn{color:#1da1f2;cursor:pointer;background:#fff;border:1px solid #1da1f2;border-radius:3px;padding:.2rem .5rem;font-size:.65rem;font-weight:500;transition:all .2s}.filter-clear-btn:hover{color:#fff;background:#1da1f2}.hashtags-list{flex-direction:column;gap:.3rem;max-height:400px;display:flex;overflow-y:auto}.hashtag-filter-item{cursor:pointer;background:#fff;border:2px solid #eee;border-radius:3px;justify-content:space-between;align-items:center;padding:.5rem;font-size:.7rem;transition:all .2s;display:flex}.hashtag-filter-item:hover{background:#f5f9ff;border-color:#1da1f2}.hashtag-filter-item.selected{background:#e3f2fd;border-color:#1da1f2}.hashtag-filter-name{color:#333;flex:1;font-weight:600}.hashtag-filter-count{color:#666;background:#f5f5f5;border-radius:3px;padding:.2rem .4rem;font-size:.65rem}.hashtag-filter-item.selected .hashtag-filter-count{color:#1da1f2;background:#fff}.no-hashtags-message{text-align:center;color:#666;padding:1rem;font-size:.7rem}
