@import url(https://fonts.googleapis.com/css?family=Roboto:400,500,700&display=swap);body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.App,body,html{background:#f5f7fa!important;color:#1a1a1a!important;font-family:Roboto,Arial,Helvetica,sans-serif;margin:0;padding:0}.hcmus-header{background:linear-gradient(135deg,#0047ab,#003d82);border-bottom:4px solid gold;box-shadow:0 4px 12px #0047ab26;color:#fff;padding:28px 0 20px}.hcmus-header-content{align-items:center;display:flex;gap:28px;margin:0 auto;max-width:1200px;padding:0 20px}.hcmus-logo{background:#fff;border:3px solid gold;border-radius:50%;box-shadow:0 4px 16px #00000026;height:80px;padding:8px;transition:transform .3s ease;width:80px}.hcmus-logo:hover{transform:scale(1.05) rotate(5deg)}.hcmus-title{font-size:2.4em;font-weight:700;letter-spacing:1.2px;margin:0 0 6px;text-shadow:2px 2px 4px #0003}.hcmus-subtitle{font-size:1.15em;font-weight:400;letter-spacing:.5px;opacity:.95}.hcmus-navbar{background:#fff;border-bottom:3px solid #0047ab;box-shadow:0 2px 8px #0047ab14}.hcmus-navbar ul{display:flex;gap:48px;justify-content:center;list-style:none;margin:0 auto;max-width:1200px;padding:0}.hcmus-navbar li{border-bottom:3px solid #0000;color:#0047ab;cursor:pointer;font-size:1.1em;font-weight:600;padding:16px 0;position:relative;transition:all .3s ease}.hcmus-navbar li:after{background:linear-gradient(90deg,#0047ab,gold);bottom:0;content:"";height:3px;left:0;position:absolute;transition:width .3s ease;width:0}.hcmus-navbar li.active:after,.hcmus-navbar li:hover:after{width:100%}.hcmus-navbar li.active,.hcmus-navbar li:hover{color:#003d82}.hcmus-main{margin:40px auto 0;max-width:1000px;padding:0 20px 50px}.input-section{background:#fff;border:2px solid #e8f0fe;border-radius:16px;border-top:4px solid #0047ab;box-shadow:0 6px 24px #0047ab1a;margin-bottom:36px;padding:36px 32px;transition:all .3s ease}.input-section:hover{border-top-color:gold;box-shadow:0 10px 36px #0047ab26;transform:translateY(-2px)}.input-section label{color:#0047ab;display:block;font-size:1.1em;font-weight:600;margin-bottom:14px;text-align:left}input[type=number],textarea{background:#fafbff;border:2px solid #e8f0fe;border-radius:10px;box-sizing:border-box;font-family:Roboto Mono,Courier New,monospace;font-size:15px;margin-bottom:12px;min-height:100px;padding:16px;resize:vertical;transition:all .3s ease;width:100%}input[type=number]:focus,textarea:focus{background:#fff;border-color:#0047ab;box-shadow:0 0 0 3px #0047ab1a;outline:none}button{background:linear-gradient(135deg,#0047ab,#003d82);border:none;border-radius:10px;box-shadow:0 4px 12px #0047ab33;color:#fff;cursor:pointer;font-size:16px;font-weight:600;letter-spacing:.8px;margin:12px 6px;overflow:hidden;padding:14px 36px;position:relative;transition:all .3s ease}button:before{background:linear-gradient(90deg,#0000,#fff3,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .5s ease;width:100%}button:hover:before{left:100%}button:hover{background:linear-gradient(135deg,#003d82,#0047ab);box-shadow:0 8px 20px #0047ab4d;transform:translateY(-3px)}button:active{transform:translateY(-1px)}button:disabled{background:#b0bec5;box-shadow:none;color:#757575;cursor:not-allowed;transform:none}button[style*="backgroundColor: #4CAF50"]{background:linear-gradient(135deg,gold,orange)!important;color:#003d82!important;font-weight:700}button[style*="backgroundColor: #4CAF50"]:hover{background:linear-gradient(135deg,orange,gold)!important}.error{background:linear-gradient(135deg,#ffebee,#ffcdd2);border-left:5px solid #c62828;box-shadow:0 2px 8px #c628281a;color:#c62828}.error,.success{border-radius:10px;font-weight:500;margin:24px 0;padding:18px;text-align:left}.success{background:linear-gradient(135deg,#e8f5e8,#c8e6c9);border-left:5px solid #4caf50;box-shadow:0 2px 8px #4caf501a;color:#2e7d32}.results{background:#fff;border:2px solid #e8f0fe;border-radius:16px;border-top:4px solid #0047ab;box-shadow:0 6px 24px #0047ab1a;margin-top:40px;padding:36px 32px}.results h2{border-bottom:3px solid gold;color:#0047ab;display:inline-block;font-size:1.8em;font-weight:700;margin-bottom:24px;padding-bottom:12px}table{background:#fff;border-collapse:initial;border-radius:12px;border-spacing:0;box-shadow:0 4px 16px #0047ab14;margin-top:20px;overflow:hidden;width:100%}td,th{border-bottom:2px solid #e8f0fe;padding:16px 14px;text-align:left}th{background:linear-gradient(135deg,#0047ab,#003d82);border-bottom:3px solid gold;color:#fff;font-size:1.05em;font-weight:600;letter-spacing:.8px;text-transform:uppercase}tr:hover{background:linear-gradient(135deg,#f5f9ff,#e8f0fe);transition:background .3s ease}tr:last-child td{border-bottom:none}.App-link{border-bottom:2px solid #0000;color:#0047ab;font-weight:500;text-decoration:none;transition:all .3s ease}.App-link:hover{border-bottom-color:gold;color:#003d82}.chart-container{background:#fff;border:2px solid #e8f0fe;border-radius:16px;border-top:4px solid #0047ab;box-shadow:0 6px 24px #0047ab1a;margin-bottom:36px;padding:36px 32px}.chart-container h3{border-bottom:2px solid gold;color:#0047ab;display:inline-block;font-size:1.4em;font-weight:600;margin-bottom:24px;padding-bottom:10px}.hcmus-footer{background:linear-gradient(135deg,#0047ab,#003d82);border-top:4px solid gold;box-shadow:0 -4px 12px #0047ab26;color:#fff;font-size:1em;margin-top:50px;padding:24px 0 14px;text-align:center}.hcmus-footer a{border-bottom:2px solid #0000;color:gold;font-weight:600;text-decoration:none;transition:all .3s ease}.hcmus-footer a:hover{border-bottom-color:gold;color:#fff}.loading{animation:spin .8s ease-in-out infinite;border:3px solid #e8f0fe;border-radius:50%;border-top-color:gold;display:inline-block;height:22px;margin-right:8px;width:22px}@keyframes spin{to{transform:rotate(1turn)}}input[type=radio]{accent-color:#0047ab;cursor:pointer;height:18px;width:18px}@media (max-width:900px){.chart-container,.hcmus-header-content,.hcmus-main,.input-section,.results{padding-left:16px;padding-right:16px}.hcmus-navbar ul{gap:32px}}@media (max-width:600px){.hcmus-header-content{align-items:center;flex-direction:column;gap:12px;text-align:center}.hcmus-logo{height:60px;width:60px}.hcmus-title{font-size:1.6em}.hcmus-subtitle{font-size:.95em}.hcmus-navbar ul{flex-direction:column;gap:0}.hcmus-navbar li{border-bottom:1px solid #e8f0fe;padding:14px 0;text-align:center;width:100%}.hcmus-main{padding:0 12px 40px}.chart-container,.input-section,.results{padding:20px 16px}button{margin:10px 0;width:100%}table{font-size:13px}td,th{padding:10px 6px}}::-webkit-scrollbar{width:12px}::-webkit-scrollbar-track{background:#f5f7fa}::-webkit-scrollbar-thumb{background:linear-gradient(135deg,#0047ab,#003d82);border-radius:6px}::-webkit-scrollbar-thumb:hover{background:linear-gradient(135deg,#003d82,#0047ab)}.network-graph-container{background:#fff;border:2px solid #e8f0fe;border-radius:16px;border-top:4px solid #0047ab;box-shadow:0 6px 24px #0047ab1a;margin:36px 0;padding:32px}.graph-header h3{border-bottom:3px solid gold;color:#0047ab;display:inline-block;font-size:1.6em;font-weight:700;margin-bottom:20px;padding-bottom:12px}.graph-controls{align-items:center;gap:16px;justify-content:space-between;margin:20px 0}.graph-controls,.legend{display:flex;flex-wrap:wrap}.legend{gap:24px}.legend-item{align-items:center;color:#555;display:flex;font-size:.95em;gap:8px}.legend-color{border:2px solid #ddd;border-radius:4px;height:20px;width:60px}.legend-icon{font-size:1.3em}.graph-instructions{background:#f5f9ff;border-left:4px solid #0047ab;border-radius:8px;color:#555;font-size:.95em;margin:16px 0;padding:14px}svg{background:linear-gradient(135deg,#fafbff,#f5f9ff);border:2px solid #e8f0fe;border-radius:12px;cursor:grab;width:100%}svg:active{cursor:grabbing}.graph-tooltip{background:#fff;border:3px solid #0047ab;border-radius:12px;box-shadow:0 8px 24px #0047ab33;font-size:.95em;max-width:350px;opacity:0;padding:16px;pointer-events:none;position:absolute;transition:opacity .3s ease;z-index:1000}.tooltip-content{line-height:1.6}.tooltip-content hr{border:none;border-top:2px solid #e8f0fe}@media (max-width:768px){.network-graph-container{padding:20px 16px}.graph-controls{align-items:flex-start;flex-direction:column}.legend{flex-direction:column;gap:12px}svg{height:400px}}.network-metrics-container{background:#fff;border:2px solid #e8f0fe;border-radius:16px;border-top:4px solid #0047ab;box-shadow:0 6px 24px #0047ab1a;margin:36px 0;padding:36px 32px}.metrics-header h3{border-bottom:3px solid gold;color:#0047ab;display:inline-block;font-size:1.8em;font-weight:700;margin-bottom:12px;padding-bottom:12px}.metrics-description{background:#f5f9ff;border-left:4px solid #0047ab;border-radius:8px;color:#666;font-size:1.05em;margin:16px 0 24px;padding:12px 16px}.metrics-overview{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));margin-bottom:36px}.metric-card{align-items:center;background:linear-gradient(135deg,#f5f9ff,#e8f0fe);border:2px solid #d1e3fc;border-radius:12px;box-shadow:0 2px 8px #0047ab14;display:flex;gap:16px;padding:20px;transition:all .3s ease}.metric-card:hover{border-color:#0047ab;box-shadow:0 6px 16px #0047ab26;transform:translateY(-4px)}.metric-icon{font-size:2.5em;opacity:.9}.metric-content{flex:1 1}.metric-value{color:#0047ab;font-size:1.8em;font-weight:700;line-height:1.2}.metric-label{color:#666;font-size:.9em;font-weight:500;margin-top:4px}.metrics-charts-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(450px,1fr));margin-bottom:36px}.chart-box{background:#fafbff;border:2px solid #e8f0fe;border-radius:12px;padding:24px;transition:all .3s ease}.chart-box:hover{border-color:#0047ab;box-shadow:0 4px 12px #0047ab1a}.chart-box h4{color:#0047ab;font-size:1.3em;font-weight:600;margin-bottom:8px}.chart-description{color:#666;font-size:.9em;margin-bottom:16px}.hub-authority-section{grid-gap:24px;display:grid;gap:24px;grid-template-columns:1fr 1fr;margin-bottom:36px}.authority-box,.hub-box{background:linear-gradient(135deg,#fff5e6,#ffe6cc);border:2px solid gold;border-radius:12px;padding:24px}.authority-box{background:linear-gradient(135deg,#e6f7ff,#cef);border-color:#0047ab}.authority-box h4,.hub-box h4{color:#0047ab;font-size:1.3em;font-weight:600;margin-bottom:8px}.section-description{color:#666;font-size:.9em;margin-bottom:16px}.authority-list,.hub-list{list-style:none;margin:0;padding:0}.authority-list li,.hub-list li{align-items:center;background:#fff;border:2px solid #e8f0fe;border-radius:8px;display:flex;gap:12px;margin-bottom:12px;padding:12px 16px;transition:all .3s ease}.authority-list li:hover,.hub-list li:hover{border-color:#0047ab;box-shadow:0 2px 8px #0047ab1a;transform:translateX(4px)}.rank-badge{background:#0047ab;border-radius:20px;color:#fff;font-size:.9em;font-weight:700;min-width:40px;padding:4px 10px;text-align:center}.rank-badge.gold{background:linear-gradient(135deg,gold,orange);color:#003d82}.authority-url,.hub-url{color:#0047ab;flex:1 1;font-size:.95em;font-weight:500;overflow:hidden;text-decoration:none;text-overflow:ellipsis;white-space:nowrap}.authority-url:hover,.hub-url:hover{text-decoration:underline}.authority-score,.hub-score{color:#666;font-size:.85em;font-weight:600;white-space:nowrap}.no-data{color:#999;font-style:italic;padding:20px;text-align:center}.insights-panel{background:linear-gradient(135deg,#f5f9ff,#e8f0fe);border:2px solid #0047ab;border-radius:12px;padding:24px}.insights-panel h4{color:#0047ab;font-size:1.4em;font-weight:600;margin-bottom:20px}.insights-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.insight-item{align-items:flex-start;background:#fff;border:2px solid #e8f0fe;border-radius:10px;display:flex;gap:12px;padding:16px;transition:all .3s ease}.insight-item:hover{border-color:#0047ab;box-shadow:0 2px 8px #0047ab1a}.insight-icon{font-size:2em;line-height:1}.insight-item strong{color:#0047ab;display:block;font-size:1.05em;margin-bottom:6px}.insight-item p{color:#666;font-size:.9em;line-height:1.5;margin:0}@media (max-width:768px){.network-metrics-container{padding:20px 16px}.metrics-overview{gap:12px;grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}.hub-authority-section,.insights-grid,.metrics-charts-grid{grid-template-columns:1fr}}
/*# sourceMappingURL=main.d9cf1e78.css.map*/