@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";:root{--font-sans: "Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--color-bg: #f8fafc;--color-surface: #ffffff;--color-text-main: #0f172a;--color-text-muted: #64748b;--color-border: #e2e8f0;--color-primary: #2563eb;--color-primary-hover: #1d4ed8;--color-primary-text: #ffffff;--color-danger: #ef4444;--color-danger-hover: #dc2626;--color-success: #22c55e;--color-accent: #8b5cf6;--color-accent-hover: #7c3aed;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--shadow-xl: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);--shadow-glow: 0 0 20px rgba(59, 130, 246, .15);--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-full: 9999px;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .2s cubic-bezier(.4, 0, .2, 1);--transition-slow: .3s cubic-bezier(.4, 0, .2, 1)}@media (prefers-color-scheme: dark){:root{--color-bg: #0b1120;--color-surface: #131c31;--color-surface-hover: #1a2540;--color-text-main: #e2e8f0;--color-text-muted: #94a3b8;--color-border: rgba(148, 163, 184, .12);--color-primary: #3b82f6;--color-primary-hover: #60a5fa;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .2);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .3), 0 2px 4px -2px rgb(0 0 0 / .2);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .3), 0 4px 6px -4px rgb(0 0 0 / .2);--shadow-xl: 0 20px 25px -5px rgb(0 0 0 / .35), 0 8px 10px -6px rgb(0 0 0 / .25);--shadow-glow: 0 0 30px rgba(59, 130, 246, .12)}}*,*:before,*:after{box-sizing:border-box}body{margin:0;font-family:var(--font-sans);background-color:var(--color-bg);color:var(--color-text-main);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}button{cursor:pointer;border:none;font-family:inherit;font-size:100%;line-height:inherit;margin:0;padding:0}h1,h2,h3,h4,h5,h6{margin:0;font-weight:600}input{font-family:inherit}@media (prefers-color-scheme: dark){::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#94a3b833;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#94a3b859}}.app-container{min-height:100vh;display:flex;flex-direction:column;background:var(--color-bg)}.dashboard-header{position:sticky;top:0;z-index:50;background:#0b1120b8;backdrop-filter:blur(16px) saturate(180%);-webkit-backdrop-filter:blur(16px) saturate(180%);border-bottom:1px solid var(--color-border);padding:.75rem 1.5rem;display:flex;justify-content:space-between;align-items:center}@media (prefers-color-scheme: light){.dashboard-header{background:#ffffffd9}}.header-left{display:flex;align-items:center;gap:1.25rem}.header-title{font-size:1.15rem;font-weight:700;background:linear-gradient(135deg,#3b82f6,#8b5cf6,#ec4899);background-size:200% 200%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.02em;animation:shimmer 6s ease-in-out infinite}@keyframes shimmer{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}.header-nav{display:flex;gap:.375rem}.header-nav-btn{display:inline-flex;align-items:center;gap:.35rem;padding:.4rem .85rem;font-size:.8rem;font-weight:500;border-radius:var(--radius-md);color:var(--color-text-muted);background:#94a3b814;border:1px solid var(--color-border);transition:all var(--transition-base);text-decoration:none;white-space:nowrap;cursor:pointer}.header-nav-btn:hover,.header-nav-btn.active{color:var(--color-text-main);background:#94a3b829;border-color:#94a3b840;transform:translateY(-1px)}.header-nav-btn.active{background:#94a3b840;border-color:var(--color-primary);color:var(--color-primary)}.header-nav-btn svg,.header-nav-btn .nav-icon{width:14px;height:14px;opacity:.7}.user-controls{display:flex;align-items:center;gap:.75rem}.namespace-selector{display:flex;align-items:center;gap:.5rem}.user-badge{display:flex;align-items:center;gap:.5rem;font-size:.825rem;color:var(--color-text-muted);background:#94a3b814;padding:.25rem .75rem .25rem .25rem;border-radius:var(--radius-full);border:1px solid var(--color-border);transition:all var(--transition-base)}.user-badge:hover{background:#94a3b824}.user-avatar{width:28px;height:28px;border-radius:50%;object-fit:cover;border:2px solid rgba(59,130,246,.3)}.logout-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.4rem .85rem;font-size:.825rem;font-weight:500;color:var(--color-danger);background:transparent;border-radius:var(--radius-md);border:1px solid transparent;transition:all var(--transition-base)}.logout-btn:hover{background:#ef44441a;border-color:#ef444433}.dashboard-main{flex:1;padding:1.75rem 2rem;max-width:1400px;margin:0 auto;width:100%;box-sizing:border-box}.dashboard-controls{margin-bottom:1.75rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}.controls-left{display:flex;gap:.5rem;flex:1;min-width:200px}.controls-right{display:flex;gap:.5rem;align-items:center}.login-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:1rem;background:radial-gradient(ellipse at top,rgba(59,130,246,.08) 0%,transparent 60%)}.login-card{background:var(--color-surface);padding:2.5rem;border-radius:var(--radius-xl);box-shadow:var(--shadow-xl),var(--shadow-glow);width:100%;max-width:400px;text-align:center;border:1px solid var(--color-border);animation:fadeInUp .5s var(--transition-slow)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.login-title{margin-bottom:1.5rem;font-size:1.5rem;background:linear-gradient(135deg,var(--color-primary),var(--color-accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.gateways-grid{display:grid;grid-template-columns:1fr;gap:.75rem;list-style:none;padding:0;margin:0}.gateway-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;transition:all var(--transition-base);animation:fadeInUp .35s ease-out both}.gateway-card:nth-child(1){animation-delay:0ms}.gateway-card:nth-child(2){animation-delay:50ms}.gateway-card:nth-child(3){animation-delay:.1s}.gateway-card:nth-child(4){animation-delay:.15s}.gateway-card:nth-child(5){animation-delay:.2s}.gateway-card:nth-child(6){animation-delay:.25s}.gateway-card:hover{border-color:#3b82f640;box-shadow:var(--shadow-md),0 0 0 1px #3b82f614}.deployment-count-badge{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:20px;padding:0 .4rem;font-size:.7rem;font-weight:600;color:var(--color-primary);background:#3b82f61f;border-radius:var(--radius-full);border:1px solid rgba(59,130,246,.2)}.gateway-header{padding:.875rem 1.25rem;display:flex;align-items:center;justify-content:space-between;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background var(--transition-fast)}.gateway-header:hover{background:#3b82f60a}.gateway-header h3{font-size:.925rem;font-weight:600;letter-spacing:-.01em;display:flex;align-items:center;gap:.5rem}.gateway-header h3:before{content:"";display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--color-success);box-shadow:0 0 6px #22c55e66;flex-shrink:0}.gateway-body{padding:0 1.25rem 1.25rem;animation:slideDown .25s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.empty-state{padding:2rem;text-align:center;color:var(--color-text-muted);font-size:.875rem}.deployments-list{list-style:none;padding:0;margin:1rem 0 0;display:flex;flex-direction:column;gap:.5rem}.deployment-item{border:1px solid var(--color-border);border-radius:var(--radius-md);padding:.25rem;background:var(--color-bg);transition:all var(--transition-base)}.deployment-item:hover{border-color:#94a3b840}.deployment-header{padding:.5rem .75rem;display:flex;align-items:center;justify-content:space-between}.deployment-info{display:flex;align-items:center;gap:.75rem}.dep-name{font-weight:500;font-size:.875rem}.dep-project{font-size:.7rem;color:var(--color-primary);background:#3b82f614;padding:.15em .5em;border-radius:var(--radius-sm);font-weight:500}.not-found-tag{font-size:.7rem;color:var(--color-danger);font-weight:500;display:inline-flex;align-items:center;gap:.25rem}.deployment-details{padding:.75rem;border-top:1px solid var(--color-border);background:#00000005;font-size:.825rem;border-radius:0 0 var(--radius-md) var(--radius-md)}@media (prefers-color-scheme: dark){.deployment-details{background:#00000026}}.container-info{margin-bottom:.5rem}.container-name{font-weight:600;color:var(--color-primary);margin-bottom:.25rem;font-size:.8rem}.env-list{margin:0;padding-left:1rem;color:var(--color-text-muted);font-size:.8rem}.env-list li{margin-bottom:.1rem}.add-exposure-form{margin-top:1.25rem;padding-top:1rem;border-top:1px dashed var(--color-border)}.form-label{display:block;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted);margin-bottom:.75rem}.form-row{display:flex;gap:.5rem;flex-wrap:wrap}.input-field{flex:1;min-width:140px;padding:.5rem .85rem;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg);color:var(--color-text-main);font-size:.85rem;transition:all var(--transition-base)}.input-field:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #3b82f61f}.input-field:disabled{background:#0000000d;color:var(--color-text-muted)}.input-field::placeholder{color:var(--color-text-muted);opacity:.6}.btn{padding:.5rem 1rem;border-radius:var(--radius-md);font-size:.825rem;font-weight:500;transition:all var(--transition-base);display:inline-flex;align-items:center;justify-content:center;gap:.4rem;white-space:nowrap}.btn-primary{background:linear-gradient(135deg,var(--color-primary),#4f8afa);color:var(--color-primary-text);box-shadow:0 1px 3px #3b82f640}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,var(--color-primary-hover),var(--color-primary));box-shadow:0 4px 12px #3b82f659;transform:translateY(-1px)}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{padding:.5rem 1rem;border-radius:var(--radius-md);font-size:.825rem;font-weight:500;transition:all var(--transition-base);display:inline-flex;align-items:center;justify-content:center;gap:.4rem;background:#94a3b814;border:1px solid var(--color-border);color:var(--color-text-main);cursor:pointer}.btn-secondary:hover:not(:disabled){background:#94a3b829;border-color:#94a3b840;transform:translateY(-1px)}.btn-secondary-sm{padding:.2rem .6rem;border-radius:var(--radius-sm);font-size:.7rem;background:transparent;border:1px solid var(--color-border);color:var(--color-text-muted);cursor:pointer;transition:all var(--transition-base)}.btn-secondary-sm:hover{background:#94a3b81f;color:var(--color-text-main)}.btn-danger-outline{border:1px solid rgba(239,68,68,.4);color:var(--color-danger);background:transparent;padding:.3rem .75rem;font-size:.75rem;transition:all var(--transition-base)}.btn-danger-outline:hover:not(:disabled){background:var(--color-danger);color:#fff;box-shadow:0 2px 8px #ef44444d}.btn-icon{background:transparent;width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--color-text-muted);font-size:1.1rem;line-height:1;transition:all var(--transition-fast)}.btn-icon:hover{background:#94a3b81f;color:var(--color-text-main)}.btn-primary-outline{border:1px solid rgba(59,130,246,.4);color:var(--color-primary);background:transparent;padding:.3rem .75rem;font-size:.75rem;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base)}.btn-primary-outline:hover:not(:disabled){background:var(--color-primary);color:#fff;box-shadow:0 2px 8px #3b82f64d}.status-msg{font-size:.75rem;margin-top:.5rem}.status-error{color:var(--color-danger)}.status-success{color:var(--color-success)}.status-link{color:var(--color-primary);text-decoration:underline;margin-left:.25rem}.view-toggles{display:flex;gap:0px}.view-toggles .btn{border-radius:0;border:1px solid var(--color-border);margin-left:-1px}.view-toggles .btn:first-child{border-top-left-radius:var(--radius-md);border-bottom-left-radius:var(--radius-md);margin-left:0}.view-toggles .btn:last-child{border-top-right-radius:var(--radius-md);border-bottom-right-radius:var(--radius-md)}.view-toggles .btn-primary{border-color:var(--color-primary);z-index:1}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;z-index:100;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .2s ease-out}.modal-content{background:var(--color-surface);padding:2rem;border-radius:var(--radius-xl);width:90%;max-width:500px;box-shadow:var(--shadow-xl);max-height:90vh;overflow-y:auto;border:1px solid var(--color-border);animation:modalIn .3s cubic-bezier(.34,1.56,.64,1)}@keyframes modalIn{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-actions{margin-top:1.5rem;display:flex;justify-content:flex-end;gap:.5rem}.form-group{margin-bottom:1rem;display:flex;flex-direction:column}.form-group label{font-size:.75rem;font-weight:600;margin-bottom:.3rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em}.env-var-row{display:flex;gap:.5rem;margin-bottom:.5rem;align-items:center}@media (max-width: 768px){.dashboard-header{padding:.625rem 1rem}.header-nav{display:none}.dashboard-main{padding:1rem}.dashboard-controls{flex-direction:column;align-items:stretch}.controls-left{min-width:unset}.controls-right{flex-wrap:wrap;justify-content:flex-end}}.build-modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;justify-content:center;align-items:center;z-index:2000;animation:fadeIn .2s ease-out}.build-modal-content{background:#0f172a;padding:2.5rem;border-radius:16px;border:1px solid rgba(51,65,85,.5);width:100%;max-width:480px;box-shadow:0 25px 50px -12px #00000080,0 0 0 1px #94a3b81a;color:#f8fafc;position:relative;overflow:hidden;animation:slideUp .3s cubic-bezier(.16,1,.3,1)}.build-modal-content:before{content:"";position:absolute;top:0;left:0;width:100%;height:4px;background:linear-gradient(90deg,#3b82f6,#ec4899)}.build-modal-content h2{margin-top:0;margin-bottom:2rem;font-size:1.5rem;font-weight:700;background:linear-gradient(to right,#60a5fa,#a78bfa,#ec4899);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;text-align:center;letter-spacing:-.02em}.build-modal-content .form-group{margin-bottom:1.5rem;position:relative;text-align:left}.build-modal-content .form-group label{display:block;margin-bottom:.5rem;font-size:.75rem;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.05em;transition:color .2s}.build-modal-content .form-group:focus-within label{color:#60a5fa}.build-modal-content .form-group input{width:100%;padding:.875rem 1rem;background-color:#1e293b;border:1px solid #334155;border-radius:8px;color:#f1f5f9;font-size:.95rem;transition:all .2s cubic-bezier(.4,0,.2,1)}.build-modal-content .form-group input:focus{outline:none;border-color:#60a5fa;background-color:#0f172a;box-shadow:0 0 0 4px #3b82f626}.build-modal-content .form-group input::placeholder{color:#475569}.build-modal-content .form-group small{display:block;margin-top:.5rem;color:#64748b;font-size:.8rem;line-height:1.4}.build-modal-content .modal-actions{display:flex;justify-content:flex-end;gap:1rem;margin-top:2.5rem;padding-top:1.5rem;border-top:1px solid rgba(51,65,85,.5)}.build-modal-content .btn-secondary{background:transparent;border:1px solid #475569;color:#cbd5e1;padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;font-weight:500;transition:all .2s}.build-modal-content .btn-secondary:hover:not(:disabled){background:#ffffff0d;color:#fff;border-color:#94a3b8}.build-modal-content .btn-primary{background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;color:#fff;padding:.75rem 2rem;border-radius:8px;cursor:pointer;font-weight:600;box-shadow:0 4px 6px -1px #3b82f666;transition:all .2s;position:relative;overflow:hidden}.build-modal-content .btn-primary:after{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(to bottom,rgba(255,255,255,.1),transparent);pointer-events:none}.build-modal-content .btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 8px 12px -1px #3b82f680;background:linear-gradient(135deg,#60a5fa,#3b82f6)}.btn-secondary:disabled,.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none!important;box-shadow:none!important}.build-modal-content .error-message{background:#ef44441a;border:1px solid rgba(239,68,68,.2);color:#fca5a5;padding:.75rem;border-radius:6px;margin-top:1rem;display:flex;align-items:center;gap:.5rem;font-size:.9rem}@media (max-width: 640px){.build-modal-content{padding:1.5rem;width:90%;max-height:90vh;overflow-y:auto}.build-modal-content h2{margin-bottom:1.5rem;font-size:1.25rem}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(20px) scale(.95);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}
