html,body,#root{min-height:100%;height:auto}*{box-sizing:border-box}body{background:#fff;color:#111}.app-shell{display:grid;grid-template-rows:56px 1fr;height:100%;font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Arial}.app-main{display:flex;flex-direction:column;min-height:0}.topnav{display:flex;align-items:center;gap:16px;padding:0 16px;border-bottom:1px solid #e5e7eb;background:#fff}.topnav .brand{font-weight:800}.topnav .tabs{display:flex;gap:12px}.topnav .tab{padding:8px 10px;border-radius:8px;color:#374151}.topnav .tab.active{background:#eef2ff;color:#111827}.topnav-black{display:flex;justify-content:space-between;align-items:center;background:#000;padding:18px 32px;height:50px;border-bottom:1px solid #222}.topnav-brand{flex-shrink:0}.logo-text{display:flex;flex-direction:column;gap:2px}.logo-university{font-size:10px;font-weight:600;color:#999;letter-spacing:1px}.logo-name{font-size:18px;font-weight:900;color:#fff;letter-spacing:.5px}.topnav-nav{display:flex;gap:24px;flex:1;justify-content:center}.nav-link{color:#fff;text-decoration:none;font-size:14px;font-weight:500;padding:8px 0;border-bottom:2px solid transparent;transition:all .3s ease}.nav-link:hover{border-bottom-color:#999}.nav-link.active{border-bottom-color:#fff;font-weight:600}.user-icon{background:transparent;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:8px;transition:opacity .3s ease}.user-icon:hover{opacity:.7}.user-logo-img{height:38px;width:auto;object-fit:contain}.user-logo-img:hover{opacity:1}.page{display:block;width:100%}.page-main{display:grid;grid-template-columns:320px 1fr;gap:16px;align-items:flex-start;margin-bottom:32px}.stats-section{flex:0 0 auto;padding-top:24px;padding-bottom:32px;margin-bottom:0}.stats-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.stats-actions{display:flex;gap:8px}.stats-card,.card{transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease}.stats-card:hover,.card:hover{transform:translateY(-2px);box-shadow:0 8px 20px #0f172a1f}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px}.stats-card{background:#fff;border-radius:12px;border:1px solid #e5e7eb;padding:16px}.stats-layout{display:flex;flex-direction:column;gap:16px;max-width:1200px;margin:0 auto 16px}.stats-row{display:grid;grid-template-columns:1fr;gap:16px}.stats-row-two{grid-template-columns:1fr}@media (min-width: 1024px){.stats-row-two{grid-template-columns:1fr 1fr}}.sidebar{background:#fff;border-right:1px solid #e5e7eb;overflow:auto;padding:12px}.row{display:flex;gap:8px;margin:6px 0;flex-wrap:wrap}.mt8{margin-top:8px}.small{font-size:13px;color:#333}button{cursor:pointer}.map-wrapper{position:relative;height:100%;min-height:100%}.map-root{height:100%;width:100%}.coords-panel{position:absolute;top:12px;right:12px;left:auto;transform:none;z-index:1000;background:#fffffff7;border:1px solid #e5e7eb;border-radius:8px;padding:10px;width:320px;box-shadow:0 4px 16px #00000014}.coords-header{font-weight:700;margin-bottom:6px;text-align:center}.coords-last{margin-bottom:6px;text-align:center}.coords-last-title{font-size:12px;color:#555}.coords-list-title{font-weight:600;margin:6px 0 4px}.coords-empty{font-size:12px;color:#777}.coords-list{max-height:160px;overflow:auto}.coords-item{display:flex;align-items:center;gap:6px;padding:2px 0}.coords-index{width:18px;color:#555;text-align:right}.coords-code{background:#f3f4f6;padding:2px 6px;border-radius:4px}.coords-x{margin-left:auto;border:none;background:transparent;font-size:16px;line-height:1;color:#999;cursor:pointer}.coords-x:hover{color:#e11d48}.coords-actions{display:flex;justify-content:flex-end;margin-top:6px}.badge{font-size:11px;border-radius:8px;padding:1px 6px;border:1px solid #d1d5db;background:#f3f4f6}.badge-start{background:#ecfeff;border-color:#06b6d4}.badge-end{background:#fff7ed;border-color:#f97316}.badge-mid{background:#eef2ff;border-color:#6366f1}.card{background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:12px;box-shadow:0 4px 12px #0000000a}.panel-title{font-size:24px;font-weight:800;margin:4px 0 10px}.kv{display:flex;justify-content:space-between;align-items:center;margin:6px 0}.kv .k{font-size:13px;color:#6b7280}.kv .v{font-size:13px;color:#111}.divider{height:1px;background:#eee;margin:10px 0}.switch-row{display:flex;gap:10px;align-items:flex-start;margin:8px 0}.switch-row input{margin-top:4px}.switch-label .label{font-weight:600}.switch-label .hint{display:block;font-size:12px;color:#6b7280;margin-top:2px}.select{padding:6px 8px;border:1px solid #d1d5db;border-radius:8px;background:#fff}.btn{padding:6px 10px;border:1px solid #d1d5db;border-radius:10px;background:#fff;cursor:pointer}.btn:hover{background:#f9fafb}.btn.ghost{background:#f8fafc}.btn.primary{background:#111827;color:#fff;border-color:#111827}.btn.primary:hover{background:#0b1220}.total{margin-top:10px;font-size:13px;color:#374151}.total strong{margin-left:6px}.tabs{display:flex;gap:8px}.tabs a,.tabs a:visited{padding:6px 10px;border-radius:8px;border:1px solid #e5e7eb;text-decoration:none;font-size:14px;color:#111;background:transparent}.tabs a.active,.tabs a.active:visited{background:#111;color:#fff}.footer{width:100%;background-color:#000;color:#fff;display:flex;flex-direction:column;gap:12px;box-sizing:border-box;padding:28px 40px;font-size:14px}.footer-row{display:flex;justify-content:space-between;align-items:center}.footer-title{font-weight:700;font-size:1rem}.footer-contact{font-size:.95rem}.footer-divider{width:100%;height:1px;background-color:#fff;opacity:.8}.footer-row-bottom{display:flex;justify-content:space-between;font-weight:700;font-size:.95rem}.footer-branch{text-align:center;flex:1}@media (max-width: 768px){.footer-row{flex-direction:column;gap:6px;text-align:center}.footer-row-bottom{flex-direction:column;gap:4px;text-align:center}}.hero-search{max-width:1100px;margin:32px auto;padding:20px 32px;background:#e3e3e3;border-radius:18px;display:flex;align-items:center;justify-content:space-between;gap:32px}.hero-question{font-size:14px;color:#111827;flex:1}.hero-divider{width:1px;align-self:stretch;background:#b8b8b8}.hero-logo-wrap{display:flex;align-items:center;justify-content:center;height:100px}.hero-bid-logo{height:120px;width:auto;object-fit:contain}.telemetry-card{padding:16px 18px;border-radius:18px;display:flex;flex-direction:column;gap:14px}.telemetry-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.telemetry-title-block{display:flex;align-items:flex-start;gap:10px}.telemetry-icon-badge{width:28px;height:28px;border-radius:999px;background:#f3f4f6;display:flex;align-items:center;justify-content:center}.telemetry-subtitle{margin:2px 0 0;font-size:11px;line-height:1.4;color:#6b7280;max-width:210px}.telemetry-actions{display:flex;gap:6px}.telemetry-file-row{display:flex;align-items:center;gap:6px;padding:8px 10px;border-radius:10px;background:#f9fafb;border:1px solid #e5e7eb;font-size:12px;color:#4b5563}.telemetry-file-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.telemetry-metrics-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px}.telemetry-metric-card{background:#f9fafb;border-color:#e5e7eb}.telemetry-metric-label{font-size:11px;color:#6b7280}.telemetry-metric-value{font-size:15px;font-weight:600;margin-top:2px}.telemetry-downsample{margin-top:4px}.telemetry-downsample-label{display:flex;justify-content:space-between;align-items:center;font-size:12px;margin-bottom:4px;color:#374151}.telemetry-downsample-value{font-variant-numeric:tabular-nums;color:#6b7280}.telemetry-hint{font-size:11px;color:#6b7280;line-height:1.5;margin-top:6px}
