:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}._root_9ia56_2{width:1200px;min-height:100vh;background:#f7f8fa;font-family:Inter,Roboto,Helvetica Neue,Arial,sans-serif;display:flex;flex-direction:column;align-items:center;box-sizing:border-box;padding:20px 0 48px}._header_9ia56_14{width:100%;max-width:1100px;margin:0 auto 32px;background:#fff;color:#181a20;border-radius:18px;padding:32px 40px 24px;display:flex;justify-content:space-between;align-items:flex-end;box-shadow:0 4px 32px #00000012;box-sizing:border-box}._headerTitle_9ia56_29{font-size:2.2rem;font-weight:700;letter-spacing:-1px}._headerStatus_9ia56_35{text-align:right}._headerStatusTitle_9ia56_39{font-weight:600;font-size:1.1rem;margin-bottom:2px}._headerStatusTime_9ia56_45{font-size:.95rem;color:#b0b3b8}._statusCard_9ia56_50{background:#fff;border-radius:18px;box-shadow:0 4px 32px #00000012;padding:32px 40px;margin:0 auto 40px;max-width:420px;min-width:320px;display:flex;align-items:center;gap:32px;justify-content:center;box-sizing:border-box}._statusDot_9ia56_65{width:56px;height:56px;border-radius:50%;background:var(--status-color, #22c55e);box-shadow:0 2px 8px #22c55e1a}._statusText_9ia56_73{font-size:2.1rem;font-weight:800;letter-spacing:-1px;color:#181a20;display:flex;align-items:center;gap:8px}._statusText_9ia56_73 span{color:var(--status-color, #22c55e);font-weight:800;margin-left:8px}._main_9ia56_89{width:100%;max-width:1100px;background:#fff;border-radius:18px;box-shadow:0 4px 32px #00000012;padding:40px 0 32px;margin:0 auto;box-sizing:border-box}._servicesTitle_9ia56_100{font-size:1.25rem;font-weight:700;color:#181a20;margin-bottom:32px;padding-left:40px}._serviceCard_9ia56_108{background:#fff;border-radius:0;box-shadow:none;padding:20px 32px 16px;margin:0;border-bottom:1px solid #ececec;display:flex;flex-direction:column;align-items:stretch}._serviceCard_9ia56_108:last-child{border-bottom:none}._serviceRow_9ia56_124{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}._serviceBarRow_9ia56_131{display:flex;align-items:center;justify-content:space-between}._serviceInfoRow_9ia56_137{display:flex;align-items:center;gap:8px}._serviceUrl_9ia56_143{font-weight:500;font-size:1.08rem;color:#222}._serviceArrow_9ia56_149{color:#bdbdbd;font-size:1.1rem;margin:0 4px}._uptime_9ia56_155{font-weight:500;font-size:1rem}._uptime_9ia56_155._up_9ia56_155{color:#22c55e}._uptime_9ia56_155._down_9ia56_164{color:#ef4444}._statusBadge_9ia56_168{display:flex;align-items:center;font-weight:500;color:#22c55e;font-size:1rem;gap:6px;margin-left:24px;background:none;box-shadow:none}._statusBadge_9ia56_168._down_9ia56_164{color:#ef4444;background:none}._statusDotSmall_9ia56_185{width:12px;height:12px;border-radius:50%;background:#22c55e;display:inline-block}._statusDotSmall_9ia56_185._down_9ia56_164{background:#ef4444}._uptimeBar_9ia56_197{display:flex;gap:4px;margin-bottom:0;margin-top:0}._uptimeBarSegment_9ia56_204{width:6px;height:24px;border-radius:4px;background:#cbcedd;transition:background .2s}._uptimeBarSegment_9ia56_204._active_9ia56_212{background:#22c55e}._uptimeBarSegment_9ia56_204._down_9ia56_164{background:#ef4444}._viewHistoryBtn_9ia56_220{border:2px solid #22c55e;color:#22c55e;background:#fff;border-radius:8px;padding:8px 24px;font-weight:600;font-size:1rem;cursor:pointer;transition:background .2s,color .2s}._viewHistoryBtn_9ia56_220:hover{background:#22c55e;color:#fff}@media (max-width: 900px){._header_9ia56_14,._main_9ia56_89{max-width:98vw;padding-left:8px;padding-right:8px}._serviceCard_9ia56_108{padding-left:8px;padding-right:8px}}._tooltip_afwjw_1{position:fixed;z-index:9999;background:#222;color:#fff;padding:6px 14px;border-radius:6px;font-size:.95rem;font-family:Inter,Roboto,Helvetica Neue,Arial,sans-serif;box-shadow:0 2px 12px #0000001f;pointer-events:none;transform:translate(-50%,-100%);white-space:nowrap;opacity:.97;transition:opacity .1s}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#f8fafc;color:#1e293b;line-height:1.6}#root{width:100%}.app{min-height:100vh}.sidebar{width:280px;background:linear-gradient(180deg,#1e293b,#334155);color:#f1f5f9;display:flex;flex-direction:column;box-shadow:4px 0 20px #0000001a;position:fixed;height:100vh;z-index:1000}.sidebar-header{padding:2rem 1.5rem 1.5rem;border-bottom:1px solid rgba(148,163,184,.2)}.sidebar-title{font-size:1.5rem;font-weight:700;margin-bottom:.5rem;background:linear-gradient(135deg,#60a5fa,#a78bfa);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.sidebar-subtitle{font-size:.875rem;color:#94a3b8;font-weight:500}.sidebar-nav{flex:1;padding:1.5rem 1rem}.nav-group{margin-bottom:1rem}.nav-group-header{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;color:#cbd5e1;background:none;border:none;border-radius:.75rem;font-weight:600;font-size:.95rem;cursor:pointer;transition:all .2s ease;width:100%;text-align:left}.nav-group-header:hover{background:#94a3b81a;color:#f1f5f9}.expand-icon{margin-left:auto;transition:transform .2s ease}.expand-icon.expanded{transform:rotate(180deg)}.nav-submenu{margin-left:1rem;margin-top:.5rem;border-left:2px solid rgba(148,163,184,.2);padding-left:1rem}.nav-link{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;color:#cbd5e1;text-decoration:none;border-radius:.75rem;font-weight:500;transition:all .2s ease;margin-bottom:.5rem}.nav-link:hover{background:#94a3b81a;color:#f1f5f9;transform:translate(4px)}.nav-link.active{background:linear-gradient(135deg,#3b82f6,#8b5cf6);color:#fff;box-shadow:0 4px 12px #3b82f64d}.sub-link{padding:.625rem .875rem;font-size:.875rem;margin-bottom:.25rem}.sub-link:hover{transform:translate(2px)}.nav-link svg{flex-shrink:0}.sidebar-footer{padding:1.5rem;border-top:1px solid rgba(148,163,184,.2)}.version-info{font-size:.75rem;color:#64748b;text-align:center}.main-content{flex:1;margin-left:280px;padding:2rem 3rem;background:#f8fafc;min-height:100vh}.page-content{width:100%;margin:0 auto}.page-header{margin-bottom:2.5rem;text-align:center}.page-header h1{font-size:2.5rem;font-weight:800;color:#1e293b;margin-bottom:.5rem;background:linear-gradient(135deg,#1e293b,#475569);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.page-header p{font-size:1.125rem;color:#64748b;font-weight:500}.content-grid{display:flex;flex-direction:column;gap:2rem;width:100%}.section-card{background:#fff;border-radius:1rem;padding:2.5rem;box-shadow:0 4px 20px #00000014;border:1px solid #e2e8f0;width:100%}.section-card h2{font-size:1.5rem;font-weight:700;color:#1e293b;margin-bottom:1.5rem}.file-upload-area{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 2rem;border:2px dashed #cbd5e1;border-radius:1rem;background:#f8fafc;cursor:pointer;transition:all .2s ease;position:relative}.file-upload-area:hover{border-color:#3b82f6;background:#eff6ff}.upload-icon{color:#64748b;margin-bottom:1rem}.upload-text{font-size:1.125rem;color:#64748b;font-weight:500}.file-input{position:absolute;opacity:0;width:100%;height:100%;cursor:pointer}.url-input-wrapper{display:flex;flex-direction:column;gap:1rem}.url-textarea{width:100%;min-height:120px;padding:1rem;border:1px solid #e2e8f0;border-radius:.75rem;font-family:inherit;font-size:.95rem;color:#1e293b;resize:vertical;background:#f8fafc;transition:all .2s ease}.url-textarea:focus{outline:none;border-color:#3b82f6;background:#fff;box-shadow:0 0 0 3px #3b82f61a}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;border:none;border-radius:.75rem;font-weight:600;font-size:.95rem;cursor:pointer;transition:all .2s ease;text-decoration:none;position:relative}.btn-primary{background:linear-gradient(135deg,#3b82f6,#8b5cf6);color:#fff;box-shadow:0 4px 12px #3b82f64d}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #3b82f666}.btn-secondary{background:#f1f5f9;color:#475569;border:1px solid #e2e8f0}.btn-secondary:hover:not(:disabled){background:#e2e8f0;color:#1e293b}.btn-large{padding:1rem 2rem;font-size:1.1rem}.btn-icon{padding:.5rem;background:transparent;color:#64748b;border-radius:.5rem}.btn-icon:hover{background:#f1f5f9;color:#3b82f6}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none!important}.action-bar{display:flex;justify-content:center;padding:2rem 0}.preview-section{margin-top:2rem}.preview-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:1rem}.preview-item{aspect-ratio:1;border-radius:.75rem;overflow:hidden;box-shadow:0 2px 8px #0000001a;border:1px solid #e2e8f0}.preview-item img{width:100%;height:100%;object-fit:cover}.results-section{margin-top:2rem}.results-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.results-table{overflow-x:auto}.results-table table{width:100%;border-collapse:separate;border-spacing:0}.results-table th{background:#f8fafc;padding:1rem;text-align:left;font-weight:600;color:#475569;border-bottom:1px solid #e2e8f0}.results-table td{padding:1rem;border-bottom:1px solid #f1f5f9;vertical-align:middle}.result-thumb{width:60px;height:60px;object-fit:cover;border-radius:.5rem;border:1px solid #e2e8f0}.location-text{font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.875rem;color:#475569;word-break:break-all}.tooltip{position:absolute;top:100%;left:50%;transform:translate(-50%);background:#1e293b;color:#fff;padding:.5rem .75rem;border-radius:.5rem;font-size:.75rem;white-space:nowrap;opacity:0;visibility:hidden;transition:all .2s ease;z-index:10;margin-top:.5rem}.btn-icon:hover .tooltip{opacity:1;visibility:visible}.error-message{display:flex;align-items:center;gap:.5rem;padding:1rem 1.5rem;background:#fef2f2;border:1px solid #fecaca;border-radius:.75rem;color:#dc2626;font-weight:500;margin:1rem 0}.svg-input-wrapper{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin-bottom:1.5rem}.svg-textarea{width:100%;min-height:300px;padding:1rem;border:1px solid #e2e8f0;border-radius:.75rem;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.875rem;color:#1e293b;resize:vertical;background:#f8fafc;transition:all .2s ease}.svg-textarea:focus{outline:none;border-color:#3b82f6;background:#fff;box-shadow:0 0 0 3px #3b82f61a}.svg-preview{display:flex;flex-direction:column}.preview-container{background:#f8fafc;border:1px solid #e2e8f0;border-radius:.75rem;padding:1rem;height:300px;overflow:auto}.preview-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.preview-header h3{font-size:.875rem;font-weight:600;color:#475569;margin:0}.preview-toggle{padding:.375rem;background:#f1f5f9;border:1px solid #e2e8f0;color:#64748b}.preview-toggle:hover{background:#e2e8f0;color:#3b82f6}.svg-preview-content{display:flex;align-items:center;justify-content:center;height:calc(100% - 2rem);border-radius:.5rem;border:1px solid #e2e8f0;transition:all .2s ease}.svg-preview-content.light{background:#fff}.svg-preview-content.dark{background:#1e293b}.svg-preview-content svg{max-width:100%;max-height:100%}.svg-result-preview{display:flex;align-items:center;justify-content:center;width:60px;height:60px;background:#f8fafc;border-radius:.5rem;border:1px solid #e2e8f0}.svg-result-preview img{max-width:100%;max-height:100%;object-fit:contain}.url-inputs-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem}.url-input-group h3{font-size:1.125rem;font-weight:600;color:#475569;margin-bottom:1rem}.preview-images-pairs{display:flex;flex-direction:column;gap:2rem}.preview-pair{display:grid;grid-template-columns:1fr 1fr;gap:2rem;align-items:start}.preview-image-container{display:flex;flex-direction:column;align-items:center;gap:1rem;background:#f8fafc;padding:1.5rem;border-radius:1rem;border:1px solid #e2e8f0}.preview-image{max-width:100%;max-height:300px;object-fit:contain;border-radius:.75rem;box-shadow:0 4px 12px #0000001a;border:1px solid #e2e8f0}.preview-label{font-size:.875rem;font-weight:600;color:#3b82f6;text-transform:uppercase;letter-spacing:.5px}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f8fafc,#e0e7ff);padding:2rem}.login-card{background:#fff;border-radius:1rem;padding:3rem;box-shadow:0 8px 32px #0000001a;border:1px solid #e2e8f0;max-width:400px;width:100%;text-align:center}.login-header{margin-bottom:2rem}.login-logo{display:inline-flex;align-items:center;justify-content:center;width:60px;height:60px;background:linear-gradient(135deg,#3b82f6,#8b5cf6);border-radius:50%;color:#fff;margin-bottom:1rem}.login-header h1{font-size:1.75rem;font-weight:700;color:#1e293b;margin-bottom:.5rem}.login-header p{color:#64748b;font-size:1rem}.login-content{display:flex;flex-direction:column;gap:1.5rem}.domain-info h3{font-size:.875rem;font-weight:600;color:#475569;margin-bottom:.5rem}.domain-list{display:flex;gap:.5rem;justify-content:center;flex-wrap:wrap}.domain-badge{background:#eff6ff;color:#3b82f6;padding:.25rem .75rem;border-radius:.375rem;font-size:.75rem;font-weight:500;border:1px solid #bfdbfe}.google-signin-btn{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:.875rem 1.5rem;background:#000;color:#fff;border:none;border-radius:.5rem;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #4285f44d}.google-signin-btn:hover:not(:disabled){background:#3367d6;transform:translateY(-1px);box-shadow:0 4px 12px #4285f466}.google-signin-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.login-footer p{font-size:.875rem;color:#64748b;margin:0}.loading-container{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#f8fafc;gap:1rem}.loading-spinner{display:flex;align-items:center;justify-content:center}.loading-container p{color:#64748b;font-size:1rem;font-weight:500}.user-info{display:flex;align-items:center;gap:.75rem;padding:1rem;background:#94a3b81a;border-radius:.75rem;margin-bottom:1rem}.user-avatar{flex-shrink:0;width:40px;height:40px;border-radius:50%;overflow:hidden;background:#3b82f6;display:flex;align-items:center;justify-content:center}.user-avatar img{width:100%;height:100%;object-fit:cover}.avatar-placeholder{color:#fff;font-weight:600;font-size:1rem;text-transform:uppercase}.user-details{flex:1;display:flex;flex-direction:column;gap:.125rem;min-width:0}.user-name{font-size:.875rem;font-weight:600;color:#f1f5f9;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-email{font-size:.75rem;color:#94a3b8;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sign-out-btn{background:none;border:none;color:#94a3b8;cursor:pointer;padding:.25rem;border-radius:.375rem;transition:all .2s ease;flex-shrink:0}.sign-out-btn:hover{background:#94a3b833;color:#f1f5f9}@media (min-width: 1200px){.main-content{padding:3rem 4rem}.section-card{padding:3rem}.preview-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}}:root{--hm-primary: #6366f1;--hm-primary-hover: #4f46e5;--hm-primary-light: #eef2ff;--hm-secondary: #64748b;--hm-secondary-hover: #475569;--hm-danger: #ef4444;--hm-danger-hover: #dc2626;--hm-success: #10b981;--hm-success-light: #d1fae5;--hm-bg-primary: #ffffff;--hm-bg-secondary: #f8fafc;--hm-bg-tertiary: #f1f5f9;--hm-border: #e2e8f0;--hm-border-light: #f1f5f9;--hm-text-primary: #0f172a;--hm-text-secondary: #64748b;--hm-text-tertiary: #94a3b8;--hm-shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--hm-shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--hm-shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--hm-shadow-xl: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);--hm-radius-sm: 6px;--hm-radius-md: 8px;--hm-radius-lg: 12px;--hm-transition: all .2s ease}.hub-mapping-container{display:flex;flex-direction:column;height:100vh;background:var(--hm-bg-secondary);overflow:hidden}.hub-mapping-header{display:flex;justify-content:space-between;align-items:center;padding:2.25rem 2.5rem;background:linear-gradient(135deg,#fff,#f9fafb);flex-shrink:0;border:1px solid var(--hm-border);border-bottom:none;border-radius:var(--hm-radius-lg) var(--hm-radius-lg) 0 0;position:relative;overflow:hidden}.hub-mapping-header:before{content:"";position:absolute;bottom:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#6366f1,#8b5cf6,#ec4899,#f59e0b);opacity:.6}.header-content h1{margin:0 0 .5rem;font-size:1.875rem;font-weight:700;color:var(--hm-text-primary);letter-spacing:-.03em;background:linear-gradient(135deg,#1e293b,#475569);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.header-content p{margin:0;font-size:.9375rem;color:var(--hm-text-secondary);font-weight:400}.header-actions{display:flex;gap:1rem;align-items:center}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1.25rem;font-size:.875rem;font-weight:500;border-radius:var(--hm-radius-md);border:none;cursor:pointer;transition:var(--hm-transition);white-space:nowrap;outline:none}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;box-shadow:0 4px 12px #6366f140;font-weight:600}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#4f46e5,#7c3aed);box-shadow:0 6px 20px #6366f159;transform:translateY(-2px)}.btn-primary:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 8px #6366f140}.btn-secondary{background:#fff;color:var(--hm-text-primary);border:1.5px solid var(--hm-border);box-shadow:0 2px 8px #0000000a;font-weight:600}.btn-secondary:hover:not(:disabled){background:#fafbfc;border-color:#6366f1;box-shadow:0 4px 12px #6366f126;transform:translateY(-1px)}.btn-danger{background:var(--hm-danger);color:#fff;box-shadow:var(--hm-shadow-sm)}.btn-danger:hover:not(:disabled){background:var(--hm-danger-hover)}.btn-add{padding:.5rem;border-radius:var(--hm-radius-sm);background:var(--hm-primary-light);color:var(--hm-primary);border:1px solid transparent;cursor:pointer;transition:var(--hm-transition)}.btn-add:hover{background:var(--hm-primary);color:#fff;transform:scale(1.05)}.btn-remove{padding:.5rem;border-radius:var(--hm-radius-sm);background:transparent;color:var(--hm-text-tertiary);border:1px solid transparent;cursor:pointer;transition:var(--hm-transition)}.btn-remove:hover{background:#fef2f2;color:var(--hm-danger)}.btn-icon{padding:.5rem;background:transparent;color:var(--hm-text-secondary);border:1px solid var(--hm-border);border-radius:var(--hm-radius-sm);cursor:pointer;transition:var(--hm-transition)}.btn-icon:hover{background:var(--hm-bg-tertiary);color:var(--hm-text-primary);border-color:var(--hm-secondary)}.hub-mapping-content{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;padding:1.5rem 0rem;flex:1;overflow:auto;min-height:0}.panel{display:flex;flex-direction:column;background:#fff;border-radius:14px;border:1.5px solid var(--hm-border);box-shadow:0 4px 16px #0000000a,0 2px 4px #00000005;overflow:hidden;min-height:0;transition:box-shadow .3s ease}.panel:hover{box-shadow:0 8px 24px #0000000f,0 4px 8px #00000008}.panel-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 1.75rem;border-bottom:2px solid #f1f5f9;background:linear-gradient(135deg,#fafbfc,#f8f9fa);position:relative}.panel-header:after{content:"";position:absolute;bottom:-2px;left:0;right:0;height:2px;background:linear-gradient(90deg,#6366f1,#8b5cf6);opacity:0;transition:opacity .3s ease}.panel:hover .panel-header:after{opacity:.3}.panel-header h2{margin:0;font-size:1.1875rem;font-weight:700;color:var(--hm-text-primary);display:flex;align-items:center;gap:.75rem;letter-spacing:-.02em}.badge{display:inline-flex;align-items:center;justify-content:center;min-width:2.25rem;height:2rem;padding:0 .75rem;background:linear-gradient(135deg,#eef2ff,#e0e7ff);color:#6366f1;border-radius:10px;font-size:.875rem;font-weight:700;box-shadow:0 2px 8px #6366f126;letter-spacing:-.01em}.panel-filters{display:flex;gap:1rem;padding:1rem 1.5rem;border-bottom:1px solid var(--hm-border-light)}.search-box{flex:1;position:relative;display:flex;align-items:center}.search-box svg{position:absolute;left:1rem;color:var(--hm-text-tertiary);pointer-events:none}.search-box input{width:100%;padding:.875rem 1.125rem .875rem 3rem;border:1.5px solid var(--hm-border);border-radius:10px;font-size:.875rem;background:#fff;color:var(--hm-text-primary);transition:all .3s ease;font-weight:500}.search-box input::placeholder{color:#94a3b8}.search-box input:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 4px #6366f114;background:#fafbfc}.filter-select{padding:.875rem 2.75rem .875rem 1.125rem;border:1.5px solid var(--hm-border);border-radius:10px;font-size:.875rem;background:#fff;color:var(--hm-text-primary);cursor:pointer;transition:all .3s ease;-webkit-appearance:none;-moz-appearance:none;appearance:none;font-weight:500;background-image:url("data:image/svg+xml,%3Csvg width='12' height='12' viewBox='0 0 12 12' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M2.5 4.5L6 8L9.5 4.5' stroke='%236366f1' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center}.filter-select:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 4px #6366f114}.filter-select:hover{border-color:#8b5cf6}.environment-select{min-width:180px;font-weight:500;background-color:#fff;box-shadow:var(--hm-shadow-sm)}.environment-select:hover{border-color:var(--hm-secondary)}.panel-content{flex:1;overflow-y:auto;overflow-x:hidden}.panel-content::-webkit-scrollbar{width:8px}.panel-content::-webkit-scrollbar-track{background:var(--hm-bg-secondary)}.panel-content::-webkit-scrollbar-thumb{background:var(--hm-border);border-radius:4px}.panel-content::-webkit-scrollbar-thumb:hover{background:var(--hm-secondary)}.hub-list{display:flex;flex-direction:column;gap:1rem;padding:1.25rem}.hub-card{position:relative;border:1px solid var(--hm-border);border-radius:12px;background:linear-gradient(to bottom,#fff,#fafbfc);transition:all .3s cubic-bezier(.4,0,.2,1);overflow:hidden}.hub-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#6366f1,#8b5cf6,#ec4899);opacity:0;transition:opacity .3s ease}.hub-card:hover{border-color:var(--hm-primary);box-shadow:0 8px 24px #6366f11f,0 4px 8px #00000014;transform:translateY(-2px)}.hub-card:hover:before{opacity:1}.hub-card-header{display:flex;align-items:flex-start;gap:1rem;padding:1.25rem 1.25rem 1rem}.hub-card-image-wrapper{flex-shrink:0}.hub-card-image{width:64px;height:64px;border-radius:12px;overflow:hidden;background:linear-gradient(135deg,#000,#51267c);display:flex;align-items:center;justify-content:center;padding:.75rem;box-shadow:0 4px 12px #667eea40;transition:transform .3s ease}.hub-card:hover .hub-card-image{transform:scale(1.05)}.hub-card-image img{width:100%;height:100%;object-fit:contain;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.hub-card-title-section{flex:1;min-width:0}.hub-card-title{margin:0 0 .625rem;font-size:1.0625rem;font-weight:600;color:var(--hm-text-primary);line-height:1.4;letter-spacing:-.01em}.hub-card-badges{display:flex;gap:.5rem;flex-wrap:wrap}.badge-type,.badge-family{display:inline-flex;align-items:center;padding:.3125rem .75rem;font-size:.6875rem;font-weight:600;border-radius:6px;letter-spacing:.025em;text-transform:uppercase}.badge-type{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e;box-shadow:0 2px 4px #92400e1a}.badge-family{background:linear-gradient(135deg,#dbeafe,#bfdbfe);color:#1e40af;box-shadow:0 2px 4px #1e40af1a}.btn-add-modern{flex-shrink:0;width:40px;height:40px;border-radius:10px;background:linear-gradient(135deg,#000,#51267c);color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 12px #6366f14d}.btn-add-modern:hover{transform:scale(1.1) rotate(90deg);box-shadow:0 6px 20px #6366f166}.btn-add-modern:active{transform:scale(1.05) rotate(90deg)}.hub-card-body{padding:0 1.25rem 1.25rem}.medallion-preview{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-radius:10px;padding:1rem;border:1px solid #e2e8f0}.medallion-preview-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.875rem;padding-bottom:.75rem;border-bottom:1px solid #e2e8f0}.medallion-preview-label{display:inline-flex;align-items:center;gap:.5rem;font-size:.8125rem;font-weight:600;color:#6366f1}.medallion-preview-label svg{width:16px;height:16px;fill:#6366f1}.medallion-items{display:flex;flex-direction:column;gap:.875rem}.medallion-preview-item{display:flex;gap:.75rem;align-items:flex-start}.medallion-preview-dot{flex-shrink:0;width:6px;height:6px;border-radius:50%;background:linear-gradient(135deg,#6366f1,#8b5cf6);margin-top:.5rem;box-shadow:0 0 0 3px #6366f11a}.medallion-preview-content{flex:1;min-width:0;display:flex;flex-direction:column;gap:.25rem}.medallion-preview-name{font-size:.8125rem;font-weight:600;color:var(--hm-text-primary);line-height:1.4}.medallion-preview-desc{font-size:.75rem;color:var(--hm-text-secondary);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.medallion-preview-more{margin-top:.25rem;padding:.5rem;text-align:center;font-size:.75rem;font-weight:500;color:#6366f1;background:#6366f10d;border-radius:6px;border:1px dashed rgba(99,102,241,.2)}.selected-hub-list{display:flex;flex-direction:column;gap:1rem;padding:1.25rem}.selected-hub-item{border:2px solid #e2e8f0;border-radius:12px;background:#fff;overflow:hidden;transition:all .2s ease}.selected-hub-item:hover{border-color:#cbd5e1;box-shadow:0 4px 12px #00000014}.selected-hub-header{display:flex;align-items:flex-start;gap:1rem;padding:1.25rem 1.25rem 1rem}.selected-hub-image-wrapper{flex-shrink:0}.selected-hub-image{width:64px;height:64px;border-radius:10px;overflow:hidden;background:linear-gradient(135deg,#000,#51267c);display:flex;align-items:center;justify-content:center;padding:.625rem;border:2px solid #e2e8f0}.selected-hub-image img{width:100%;height:100%;object-fit:contain}.selected-hub-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:.5rem}.selected-hub-title-row{display:flex;align-items:center;gap:.625rem;flex-wrap:wrap}.selected-hub-info h3{margin:0;font-size:1rem;font-weight:600;color:#0f172a}.badge-selected{display:inline-flex;align-items:center;padding:.25rem .625rem;background:#ecfdf5;color:#059669;border:1px solid #d1fae5;border-radius:6px;font-size:.6875rem;font-weight:600}.selected-hub-meta{display:flex;gap:.5rem;flex-wrap:wrap;align-items:center}.badge-type-small,.badge-family-small{display:inline-flex;align-items:center;padding:.1875rem .5rem;font-size:.6875rem;font-weight:600;border-radius:4px;text-transform:uppercase;letter-spacing:.025em}.badge-type-small{background:#fef3c7;color:#92400e}.badge-family-small{background:#dbeafe;color:#1e40af}.selected-hub-id{display:flex;align-items:center;gap:.375rem;font-size:.6875rem;color:#94a3b8;font-family:Monaco,Courier New,monospace}.selected-hub-id svg{fill:#94a3b8}.selected-hub-id span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.btn-remove-modern{flex-shrink:0;width:32px;height:32px;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.btn-remove-modern:hover{background:#fef2f2;border-color:#fecaca}.selected-hub-body{padding:0 1.25rem 1.25rem}.medallion-list{display:flex;flex-direction:column;gap:.75rem}.medallion-item-modern{border-radius:10px;transition:all .2s ease;background:#fff}.medallion-item-modern.selected{border:2px solid #6366f1;background:#fafbfc}.medallion-item-modern.unselected{border:2px solid #e2e8f0;background:#fff}.medallion-item-modern:hover{border-color:#cbd5e1;box-shadow:0 2px 8px #0000000f}.medallion-item-main{display:flex;align-items:start;gap:1rem;padding:1rem 1rem .5rem}.medallion-item-body{display:flex;flex-direction:column;gap:.5rem;padding:0 1rem 1rem 3.5rem}.medallion-checkbox-modern{position:relative;cursor:pointer;flex-shrink:0;display:inline-block}.medallion-checkbox-modern input[type=checkbox]{position:absolute;opacity:0;cursor:pointer;width:20px;height:20px;top:0;left:0;margin:0}.checkmark-modern{display:block;width:24px;height:24px;border:2px solid #cbd5e1;border-radius:6px;background:#fff;transition:all .2s ease;position:relative;box-sizing:border-box;margin-top:.25rem}.medallion-checkbox-modern input:checked~.checkmark-modern{background:#6366f1;border-color:#6366f1}.medallion-checkbox-modern input:checked~.checkmark-modern:after{content:"";position:absolute;top:2px;left:6px;width:6px;height:10px;border:solid white;border-width:0 2.5px 2.5px 0;transform:rotate(45deg)}.medallion-checkbox-modern:hover .checkmark-modern{border-color:#6366f1}.medallion-name{margin:0;font-size:.9375rem;font-weight:600;color:#0f172a;flex:1;min-width:0}.medallion-badge-required{display:inline-flex;align-items:center;padding:.1875rem .5rem;background:#fef3c7;color:#92400e;border-radius:4px;font-size:.6875rem;font-weight:600;text-transform:lowercase}.medallion-description{margin:0;font-size:.8125rem;color:#64748b;line-height:1.6}.medallion-id-row{display:flex;align-items:center;gap:.375rem}.medallion-id-row svg{fill:#94a3b8}.medallion-id-text{font-size:.6875rem;color:#94a3b8;font-family:Monaco,Courier New,monospace}.medallion-points-modern{display:flex;flex-direction:column;gap:.375rem;flex-shrink:0;width:120px;margin-left:auto}.points-label{font-size:.6875rem;font-weight:600;color:#6366f1;letter-spacing:.025em;text-transform:uppercase;text-align:right}.points-input{width:100%;padding:.625rem .75rem;border:2px solid #e2e8f0;border-radius:8px;font-size:.9375rem;font-weight:600;color:#0f172a;text-align:center;transition:all .2s ease;background:#fff}.points-input:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.points-input::placeholder{color:#cbd5e1;font-weight:400}.stats-bar{display:flex;align-items:center;gap:2.5rem;padding:1.25rem 2.5rem;border:1px solid var(--hm-border);background:linear-gradient(135deg,#fafbfc,#fff);flex-shrink:0;box-shadow:0 2px 8px #00000005}.stat-item{display:flex;align-items:center;gap:.75rem}.stat-label{font-size:.8125rem;color:var(--hm-text-secondary);font-weight:600;letter-spacing:.01em}.stat-value{font-size:1.375rem;font-weight:700;background:linear-gradient(135deg,#6366f1,#8b5cf6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.stat-actions{margin-left:auto}.json-drawer{position:fixed;bottom:0;left:0;right:0;max-height:50vh;background:var(--hm-bg-primary);border-top:2px solid var(--hm-primary);box-shadow:var(--hm-shadow-xl);display:flex;flex-direction:column;animation:slideUp .3s ease;z-index:9999}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.json-drawer-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;border-bottom:1px solid var(--hm-border);background:var(--hm-bg-secondary)}.json-drawer-header h3{margin:0;font-size:1rem;font-weight:600;color:var(--hm-text-primary)}.json-drawer-actions{display:flex;gap:.5rem}.json-preview{flex:1;margin:0;padding:1.5rem 2rem;overflow:auto;font-family:Monaco,Courier New,monospace;font-size:.8rem;line-height:1.6;color:var(--hm-text-primary);background:var(--hm-bg-secondary)}.json-preview::-webkit-scrollbar{width:10px;height:10px}.json-preview::-webkit-scrollbar-track{background:var(--hm-bg-tertiary)}.json-preview::-webkit-scrollbar-thumb{background:var(--hm-border);border-radius:5px}.json-preview::-webkit-scrollbar-thumb:hover{background:var(--hm-secondary)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center;color:var(--hm-text-tertiary)}.empty-state svg{margin-bottom:1rem;opacity:.5}.empty-state p{margin:0 0 .5rem;font-size:1rem;font-weight:600;color:var(--hm-text-secondary)}.empty-state span{font-size:.875rem;color:var(--hm-text-tertiary)}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;gap:1.5rem}.spinner{width:48px;height:48px;border:4px solid var(--hm-border);border-top-color:var(--hm-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-state p{margin:0;font-size:1rem;font-weight:500;color:var(--hm-text-secondary)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--hm-bg-primary);border-radius:var(--hm-radius-lg);box-shadow:var(--hm-shadow-xl);width:90%;max-width:600px;max-height:80vh;display:flex;flex-direction:column;animation:slideIn .3s ease}@keyframes slideIn{0%{transform:translateY(-20px) scale(.95);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;border-bottom:1px solid var(--hm-border)}.modal-header h3{margin:0;font-size:1.25rem;font-weight:600;color:var(--hm-text-primary)}.btn-close{padding:.5rem;background:transparent;border:none;color:var(--hm-text-tertiary);cursor:pointer;border-radius:var(--hm-radius-sm);transition:var(--hm-transition)}.btn-close:hover{background:var(--hm-bg-tertiary);color:var(--hm-text-primary)}.modal-body{padding:1rem 2rem;overflow-y:auto;flex:1}.modal-body::-webkit-scrollbar{width:8px}.modal-body::-webkit-scrollbar-track{background:var(--hm-bg-secondary)}.modal-body::-webkit-scrollbar-thumb{background:var(--hm-border);border-radius:4px}.modal-body::-webkit-scrollbar-thumb:hover{background:var(--hm-secondary)}.modal-description{margin:0 0 1.5rem;font-size:.95rem;color:var(--hm-text-secondary);text-align:center}.import-options{display:flex;flex-direction:column;gap:1.5rem}.import-option-card{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:2rem;border:2px dashed var(--hm-border);border-radius:var(--hm-radius-md);background:var(--hm-bg-secondary);cursor:pointer;transition:var(--hm-transition)}.import-option-card:hover{border-color:var(--hm-primary);background:var(--hm-primary-light)}.import-option-card svg{color:var(--hm-primary)}.import-option-card span{font-size:1rem;font-weight:500;color:var(--hm-text-primary)}.import-option-divider{text-align:center;font-size:.875rem;font-weight:600;color:var(--hm-text-tertiary);position:relative}.import-option-divider:before,.import-option-divider:after{content:"";position:absolute;top:50%;width:40%;height:1px;background:var(--hm-border)}.import-option-divider:before{left:0}.import-option-divider:after{right:0}.import-option-paste{display:flex;flex-direction:column;gap:.75rem}.paste-header{display:flex;justify-content:space-between;align-items:center}.paste-header label{font-size:.875rem;font-weight:600;color:var(--hm-text-primary)}.btn-small{padding:.375rem .75rem;font-size:.8rem}.json-textarea{width:100%;min-height:200px;padding:1rem;border:1px solid var(--hm-border);border-radius:var(--hm-radius-md);font-family:Monaco,Courier New,monospace;font-size:.8rem;line-height:1.6;color:var(--hm-text-primary);background:var(--hm-bg-secondary);resize:vertical;transition:var(--hm-transition)}.json-textarea:focus{outline:none;border-color:var(--hm-primary);box-shadow:0 0 0 3px var(--hm-primary-light)}.json-textarea::placeholder{color:var(--hm-text-tertiary)}.modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1.5rem 2rem;border-top:1px solid var(--hm-border);background:var(--hm-bg-secondary);border-radius:0 0 var(--hm-radius-lg) var(--hm-radius-lg)}@media (max-width: 1400px){.hub-mapping-content{grid-template-columns:1fr 1fr}}
