html,body,#root{height:100%}:root{font-family:Inter,system-ui,sans-serif;color:#1f2933;background-color:#f5f7fa}body{margin:0;background-color:#f5f7fa}.app-shell{height:100vh;background-color:#f5f7fa;display:flex;flex-direction:column}.app-container{display:grid;grid-template-columns:280px 360px 1fr;grid-template-rows:auto;flex:1;min-height:0;padding:24px;gap:24px;overflow:hidden}.sidebar,.networks-panel,.details-panel{padding:16px;overflow-y:auto;height:100%;max-height:100%;min-height:0}.panel-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap}.panel-controls{display:inline-flex;align-items:center;gap:8px;margin-left:auto}.search-input{width:100%;padding:9px 12px;margin-bottom:14px;border:1px solid #cbd5e1;border-radius:6px;font-size:.95rem;transition:border-color .2s ease,box-shadow .2s ease}.search-input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb26}.sidebar{background:#fff;border-right:1px solid #d9e2ec}.sidebar-toggle{margin-bottom:16px}.networks-panel{background:#f8fafc;border-right:1px solid #d9e2ec}.details-panel{background:#fff;padding:16px;border-radius:12px;box-shadow:0 12px 30px #0f172a14;display:flex;flex-direction:column;gap:16px}.details-content{background:#fff;border-radius:12px;padding:16px;box-shadow:0 8px 24px #0f172a0f}.search-card{background:#fff;border-radius:12px;padding:16px;box-shadow:0 6px 18px #0f172a14}.search-card-label{font-size:.95rem;font-weight:600;display:block;margin-bottom:6px;color:#0f172a}.search-results{list-style:none;margin:12px 0 0;padding:0;display:flex;flex-direction:column;gap:8px}.search-result-item{border:1px solid #e2e8f0;border-radius:10px;padding:10px 12px;background:#f8fafc}.search-result-header{display:flex;align-items:center;justify-content:space-between;gap:8px}.search-result-meta{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}.chip{display:inline-flex;align-items:center;border-radius:999px;font-size:.75rem;padding:2px 10px;background:#e2e8f0;color:#0f172a;font-weight:600}.chip.strong{background:#0f172a;color:#fff}.chip.outline{background:transparent;border:1px solid #94a3b8;color:#475569}.chip-row{display:flex;flex-wrap:wrap;gap:6px;margin:6px 0}.chip.muted{background:#f1f5f9;color:#475569}.search-hint{font-size:.85rem;color:#64748b;margin:4px 0 0}.search-error{font-size:.85rem;color:#b91c1c;margin:4px 0 0}.panel-title{font-size:1.1rem;font-weight:600;margin:0}.panel-toggle,.sidebar-toggle{display:inline-flex;gap:4px;background:#fff;padding:4px;border-radius:999px;border:1px solid #cbd5e1}.sidebar-toggle{width:100%}.panel-toggle button,.sidebar-toggle button{border:none;background:transparent;border-radius:999px;padding:6px 14px;font-weight:600;color:#475569;cursor:pointer;transition:background .2s ease,color .2s ease,box-shadow .2s ease}.sidebar-toggle button{flex:1}.panel-toggle button.active,.sidebar-toggle button.active{background:#0f172a;color:#fff;box-shadow:0 3px 8px #0f172a33}.panel-toggle button:hover,.sidebar-toggle button:hover{color:#0f172a}.icon-button{border:1px solid #cbd5e1;background:#fff;font-size:.95rem;cursor:pointer;padding:0;width:36px;height:36px;border-radius:10px;color:#475569;display:inline-flex;align-items:center;justify-content:center;transition:background .2s ease,color .2s ease,box-shadow .2s ease}.icon-button.active{background:#0f172a;color:#fff;box-shadow:0 4px 12px #0f172a40}.icon-button:hover{color:#0f172a;box-shadow:0 4px 10px #0f172a26}.list{list-style:none;margin:0;padding:0}.list-item{border-radius:8px;padding:10px 12px;margin-bottom:8px;cursor:pointer;transition:background .15s ease}.list-item:hover{background:#eef2f7}.list-item.active{background:#2563eb;color:#fff}.list-item.active .tag{background:#edf2ff;color:#0f172a}.badge{display:inline-block;background:#dbeafe;color:#1d4ed8;font-size:.75rem;border-radius:999px;padding:2px 8px;margin-left:8px}.section{margin-bottom:24px}.section h3{margin:0 0 8px;font-size:1rem;font-weight:600}.section h4{margin:16px 0 6px;font-size:.95rem;font-weight:600}.table{width:100%;border-collapse:collapse;font-size:.9rem}.table th,.table td{text-align:left;padding:6px 8px;border-bottom:1px solid #e2e8f0}.table th{background:#f1f5f9;font-weight:600}.empty-state{color:#64748b;font-size:.9rem}.tag-list{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}.tag{background:#e2e8f0;padding:2px 6px;border-radius:6px;font-size:.75rem}.endpoint-card{border:1px solid #e2e8f0;border-radius:8px;padding:10px 12px;margin-bottom:10px;background:#f8fafc}.highlight{color:#2563eb;font-weight:600}.header{position:sticky;top:0;z-index:1000;background:#0a2d62;color:#fff;padding:18px 28px;box-shadow:0 4px 16px #00000026;display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}.header-content{display:flex;align-items:center;gap:18px;flex:1}.header-actions{display:flex;align-items:center;gap:16px;flex-wrap:wrap}.header-logo{height:40px;width:auto}.header h1{margin:0 0 6px;font-size:1.8rem}.header p{margin:0;opacity:.9}.view-hint{margin-top:12px;text-align:center}.link-button{background:none;border:none;padding:0;color:#2563eb;font-weight:600;cursor:pointer}.user-chip{background:#ffffff14;border-radius:16px;padding:10px 16px;display:flex;align-items:flex-start;gap:12px;min-width:220px}.user-chip strong{display:block;font-size:1rem}.user-chip span{display:block;font-size:.85rem;opacity:.9}.user-chip .link-button{color:#f8fafc;border:1px solid rgba(255,255,255,.4);border-radius:999px;padding:4px 12px}.user-chip .link-button:hover{background:#fff3}.import-controls{display:flex;flex-direction:column;gap:6px}.version-tag{font-size:.85rem;color:#e2e8f0;border:1px solid rgba(255,255,255,.3);border-radius:999px;padding:4px 10px}.primary-button{border:none;background:#f97316;color:#fff;font-weight:600;border-radius:999px;padding:8px 16px;cursor:pointer;transition:opacity .2s ease,transform .2s ease}.primary-button:disabled{opacity:.6;cursor:not-allowed}.import-status{font-size:.85rem}.import-status.success{color:#bbf7d0}.import-status.error{color:#fecaca}.auth-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0a2d62,#1d4ed8);padding:24px}.auth-card{width:100%;max-width:420px;background:#fff;border-radius:16px;padding:32px;box-shadow:0 30px 80px #0f172a40;text-align:center}.auth-logo{width:72px;height:auto;margin-bottom:12px}.auth-subtitle{margin:0 0 16px;color:#475569}.auth-error{background:#fee2e2;color:#b91c1c;border-radius:10px;padding:10px 12px;margin-bottom:12px;font-size:.9rem}.auth-form{display:flex;flex-direction:column;gap:10px;text-align:left}.auth-label{font-size:.85rem;font-weight:600;color:#0f172a}.auth-input{width:100%;border:1px solid #d3dce6;border-radius:8px;padding:10px 12px;font-size:1rem;transition:border-color .2s ease,box-shadow .2s ease}.auth-input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb26}.auth-submit{margin-top:10px;border:none;border-radius:10px;background:#0a2d62;color:#fff;font-size:1rem;font-weight:600;padding:10px 14px;cursor:pointer;transition:background .2s ease}.auth-submit:disabled{opacity:.6;cursor:not-allowed}.auth-divider{display:flex;align-items:center;gap:12px;color:#94a3b8;font-size:.85rem;margin:20px 0 12px}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:#e2e8f0}.google-button{width:100%;border:1px solid #2563eb;border-radius:10px;background:#fff;color:#2563eb;font-weight:600;padding:10px 14px;cursor:pointer;transition:background .2s ease,color .2s ease}.google-button:hover{background:#2563eb14}.google-button:disabled{opacity:.6;cursor:not-allowed}.auth-hint{font-size:.85rem;color:#64748b;margin-top:12px}.auth-hint.muted{color:#94a3b8}.link-button:hover{text-decoration:underline}.pie-chart-container{display:flex;flex-wrap:wrap;gap:24px;align-items:center;justify-content:center}.pie-chart{max-width:260px;max-height:260px}.pie-slice{cursor:pointer;transition:opacity .2s ease}.pie-slice.hovered{opacity:.75}.pie-slice:hover{opacity:.85}.pie-legend{display:flex;flex-direction:column;gap:8px;max-width:280px}.pie-legend-item{display:flex;align-items:center;gap:10px;cursor:pointer;padding:4px 0}.pie-legend-color{width:14px;height:14px;border-radius:50%;flex-shrink:0}.pie-legend-meta{font-size:.85rem;color:#475569}@media (max-width: 1200px){.app-container{grid-template-columns:1fr;padding:16px;gap:16px}.sidebar,.networks-panel,.details-panel{border-right:none;border-bottom:1px solid #d9e2ec}}.table-wrapper{overflow-x:auto}.table.compact th,.table.compact td{font-size:.8rem;padding:4px 6px}.card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:12px}.data-card{border:1px solid #e2e8f0;border-radius:10px;padding:12px;background:#fff;display:flex;flex-direction:column;gap:8px;box-shadow:0 1px 2px #0f172a0d}.data-card-header{display:flex;align-items:center;justify-content:space-between;gap:8px}.data-card-title{font-weight:600;color:#0f172a}.apn-chip{background:#0f172a;color:#fff;padding:2px 10px;border-radius:999px;font-size:.8rem}.data-row{display:flex;justify-content:space-between;gap:12px;font-size:.85rem}.data-row .label{color:#475569;font-weight:600}.tag-list.wrap{flex-wrap:wrap}.tag-list.compact{flex-wrap:wrap;gap:4px}.tag-list.compact .tag{font-size:.7rem;padding:2px 5px}.tag-strong{background:#0f172a;color:#fff}.panel-subtitle{margin:-6px 0 12px;color:#475569;font-size:.85rem;padding-top:8px}
