.loader-container{display:flex;justify-content:center;align-items:center;padding:2rem}.loader{border:4px solid #f3f3f3;border-top:4px solid #3498db;border-radius:50%;width:30px;height:30px;animation:spin 2s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.modal-backdrop{position:fixed;inset:0;background-color:#0f172a99;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{background-color:#fff;border-radius:8px;width:90%;max-width:600px;max-height:90vh;overflow:hidden;box-shadow:0 4px 20px #0000000d;display:flex;flex-direction:column;animation:popIn .2s cubic-bezier(.175,.885,.32,1.275) forwards}@keyframes popIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.modal-header{padding:1.25rem 1.5rem;background-color:#f1f5f9bf;border-bottom:1px solid rgba(0,0,0,.05);display:flex;justify-content:space-between;align-items:center}.modal-header h2{margin:0;font-size:1.25rem;color:#0f172a}.close-btn{background:none;border:none;font-size:1.5rem;color:#94a3b8;cursor:pointer;transition:color .15s}.close-btn:hover{color:#475569}.modal-body{padding:1.5rem;overflow-y:auto;flex:1}@media(max-width:600px){.modal-content{width:95%}.modal-header,.modal-body{padding:1rem}}.btn{padding:.45rem 1.1rem;border:none;border-radius:8px;cursor:pointer;font-weight:500;font-size:14px;font-family:inherit;transition:all .12s ease-in-out;box-shadow:0 1px 2px #0000000d}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important;box-shadow:0 1px 2px #0000000d!important}.btn:hover{transform:translateY(-1px);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.btn:active{transform:translateY(0)}.btn-primary{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff}.btn-primary:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 4px 6px -1px #2563eb66,0 2px 4px -1px #2563eb33}.btn-secondary{background-color:#f1f5f9;color:#475569}.btn-secondary:hover{background-color:#e2e8f0}.btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.btn-danger:hover{background:linear-gradient(135deg,#f87171,#ef4444)}.btn-outline{background:#fff;border:1px solid #bfdbfe;color:#3b82f6;box-shadow:none}.btn-outline:hover{background-color:#eff6ff;border-color:#93c5fd;color:#2563eb;box-shadow:none}.btn-outline-danger{background:#fff;border:1px solid #fecaca;color:#ef4444;box-shadow:none}.btn-outline-danger:hover{background-color:#fef2f2;border-color:#fca5a5;color:#dc2626;box-shadow:none}.search-clear-btn{position:absolute;right:.5rem;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;padding:.2rem;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#94a3b8;transition:color .12s ease-in-out,background-color .12s ease-in-out}.search-clear-btn:hover{color:#475569;background-color:#f1f5f9}.refresh-btn{background:none;border:none;cursor:pointer;padding:.25rem;border-radius:4px;color:#94a3b8;display:inline-flex;align-items:center;transition:color .12s,transform .12s}.refresh-btn:hover{color:#3b82f6;transform:rotate(45deg)}.textbox{width:100%;padding:.45rem .65rem;border:1px solid #cbd5e1;border-radius:8px;box-sizing:border-box;font-family:inherit;font-size:14px;color:#334155;transition:border-color .2s,box-shadow .2s}.textbox:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f62e}.textarea{min-height:80px;resize:vertical}.field{margin-bottom:1rem}.field label{display:block;font-weight:600;font-size:13px;color:#475569;margin-bottom:.25rem}.horizontal-group{display:flex;gap:1rem}.horizontal-group .field{flex:1}@media(max-width:600px){.horizontal-group{flex-direction:column;gap:0}}.form{display:flex;flex-direction:column}.edit-catalogue-form .field label,.detail-section .field label{display:inline-flex;align-items:center;gap:.35rem}.edit-catalogue-form .field label svg{color:#94a3b8}.deployments{margin-top:1rem;overflow-x:auto}.catalogue-banner{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;padding:2rem 2rem 1.85rem;background:linear-gradient(135deg,#2563eb,#4f46e5)}@media(max-width:600px){.catalogue-banner{padding:1.25rem 1rem}}.catalogue-title{margin:0;display:flex;align-items:center;gap:.75rem;font-size:1.75rem;font-weight:700;letter-spacing:-.025em;color:#fff}.catalogue-count-badge{font-size:13px;font-weight:700;color:#2563eb;background:#ffffffeb;padding:.15rem .65rem;border-radius:999px;line-height:1.4;letter-spacing:.02em}.catalogue-logout{display:inline-flex;align-items:center;gap:.35rem;color:#ffffffbf;font-size:13px;text-decoration:none;padding:.4rem .85rem;border-radius:7px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);transition:background .12s,color .12s,border-color .12s}.catalogue-logout:hover{color:#fff;background:#fff3;border-color:#ffffff59}.catalogue-type-icon{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:7px;color:#475569;flex-shrink:0;transition:background-color .12s,color .12s,border-color .12s}tbody tr:hover .catalogue-type-icon{background:#dbeafe;border-color:#bfdbfe;color:#2563eb}.catalogue-name-cell{display:flex;align-items:center;gap:.65rem}.catalogue-name-text{display:flex;flex-direction:column;min-width:0}.catalogue-name-primary{font-weight:500;color:#0f172a;line-height:1.2}.catalogue-name-secondary{font-size:11px;color:#94a3b8;margin-top:1px;font-family:ui-monospace,SF Mono,Menlo,Consolas,monospace}.catalogue-error{display:flex;align-items:flex-start;gap:.6rem;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;padding:.85rem 1rem;margin-top:1rem;color:#dc2626}.catalogue-error h2{margin:0 0 .25rem;font-size:14px;color:#dc2626}.catalogue-error p{margin:0;font-size:13px}.deployment-logs{overflow-x:visible}.deployment-logs tbody tr:hover{background-color:#f8fafc}.deployment-logs-empty{text-align:center;padding:2rem 1rem;color:#666}.dl-summary{display:flex;align-items:center;justify-content:space-between;padding:0 0 .5rem;font-size:12px;color:#64748b}.dl-count{font-weight:500}.dl-reset{background:none;border:none;cursor:pointer;color:#3b82f6;font-size:12px;font-weight:500;padding:.2rem .5rem;border-radius:4px;transition:background-color .12s ease-in-out}.dl-reset:hover{background-color:#eff6ff}.dl-filter{position:relative;display:inline-flex;align-items:center;gap:.35rem}.dl-filter-btn{background:none;border:1px solid transparent;border-radius:4px;padding:2px 4px;cursor:pointer;color:#94a3b8;display:inline-flex;align-items:center;gap:3px;transition:color .12s,background-color .12s,border-color .12s;line-height:1}.dl-filter-btn:hover{color:#3b82f6;background-color:#eff6ff}.dl-filter-btn.is-active{color:#2563eb;background-color:#dbeafe;border-color:#bfdbfe}.dl-filter-count{font-size:10px;font-weight:700;letter-spacing:0;text-transform:none;line-height:1}.dl-filter-popover{position:absolute;top:calc(100% + 6px);left:0;z-index:20;min-width:200px;max-width:280px;background-color:#fff;border:1px solid #e2e8f0;border-radius:6px;box-shadow:0 10px 25px -5px #0000001f,0 4px 10px -3px #0000000f;overflow:hidden;animation:dl-pop-in .12s ease-out}@keyframes dl-pop-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.dl-filter-popover-header{display:flex;align-items:center;gap:.25rem;padding:.4rem;border-bottom:1px solid #f1f5f9}.dl-filter-search{flex:1;border:1px solid #e2e8f0;border-radius:4px;padding:.3rem .5rem;font-size:12px;font-family:inherit;color:#334155;outline:none;text-transform:none;letter-spacing:0;font-weight:400}.dl-filter-search:focus{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f626}.dl-filter-clear{background:none;border:none;cursor:pointer;color:#94a3b8;padding:.25rem;border-radius:4px;display:inline-flex;align-items:center;justify-content:center;transition:color .12s,background-color .12s}.dl-filter-clear:hover{color:#475569;background-color:#f1f5f9}.dl-filter-list{list-style:none;margin:0;padding:.25rem;max-height:220px;overflow-y:auto}.dl-filter-list li{padding:0}.dl-filter-option{width:100%;display:flex;align-items:center;gap:.5rem;padding:.4rem .5rem;background:none;border:none;cursor:pointer;border-radius:4px;font-size:13px;font-family:inherit;color:#334155;text-align:left;text-transform:none;letter-spacing:0;font-weight:400;transition:background-color .1s}.dl-filter-option:hover{background-color:#f1f5f9}.dl-filter-option.is-checked{color:#1e3a8a;font-weight:500}.dl-filter-check{width:16px;height:16px;border-radius:3px;border:1.5px solid #cbd5e1;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;background-color:#fff;transition:background-color .1s,border-color .1s}.dl-filter-option.is-checked .dl-filter-check{background-color:#3b82f6;border-color:#3b82f6;color:#fff}.dl-filter-value{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dl-filter-empty{padding:.6rem .75rem;font-size:12px;color:#94a3b8;text-align:center}.dl-summary-actions{display:flex;align-items:center;gap:.5rem}.dl-chart-toggle{background:none;border:1px solid #e2e8f0;border-radius:4px;cursor:pointer;color:#64748b;font-size:12px;font-weight:500;font-family:inherit;padding:.2rem .5rem;display:inline-flex;align-items:center;gap:.3rem;transition:color .12s,background-color .12s,border-color .12s}.dl-chart-toggle:hover{color:#3b82f6;background-color:#eff6ff;border-color:#bfdbfe}.dl-chart-toggle.is-active{color:#2563eb;background-color:#dbeafe;border-color:#bfdbfe}.dl-chart-wrapper{position:relative;margin-bottom:1rem;background:#fff;border:1px solid #e2e8f0;border-radius:6px;padding:.75rem .75rem .25rem}.dl-chart-svg{width:100%;height:auto;display:block;overflow:visible}.dl-chart-bar{fill:#3b82f6;opacity:.8;cursor:default;transition:opacity .1s}.dl-chart-bar:hover{opacity:1}.dl-chart-bar.is-zero{fill:#e2e8f0;opacity:1}.dl-chart-axis{stroke:#e2e8f0;stroke-width:1}.dl-chart-label{font-size:9px;fill:#94a3b8;font-family:inherit}.dl-chart-tooltip{position:absolute;background:#1e293b;color:#f8fafc;border-radius:5px;padding:.3rem .6rem;font-size:12px;pointer-events:none;white-space:nowrap;display:flex;flex-direction:column;gap:1px;z-index:10;box-shadow:0 4px 12px #00000026}.dl-chart-tooltip strong{font-weight:600;font-size:11px;color:#94a3b8}.detail-banner{background:linear-gradient(135deg,#2563eb,#4f46e5);padding:1.5rem 2rem 1.75rem}@media(max-width:600px){.detail-banner{padding:1.1rem 1rem 1.35rem}}.detail-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem;flex-wrap:wrap;gap:.75rem}.detail-back-btn{display:inline-flex;align-items:center;gap:.4rem;background:#ffffff1f;border:1px solid rgba(255,255,255,.25);cursor:pointer;color:#ffffffe6;font-size:13px;font-weight:500;font-family:inherit;padding:.35rem .75rem;border-radius:7px;transition:background .12s,color .12s,border-color .12s}.detail-back-btn:hover{background:#ffffff38;color:#fff;border-color:#ffffff6b}.detail-back-btn:hover svg{transform:translate(-2px);transition:transform .15s}.detail-header-actions{display:flex;align-items:center;gap:.75rem}.detail-banner .btn-outline{background:#ffffff1f;border-color:#ffffff52;color:#ffffffe6;box-shadow:none}.detail-banner .btn-outline:hover{background:#ffffff38;border-color:#ffffff85;color:#fff;box-shadow:none}.detail-banner .btn-outline-danger{background:#ef444426;border-color:#fca5a561;color:#fca5a5;box-shadow:none}.detail-banner .btn-outline-danger:hover{background:#ef444447;border-color:#fca5a594;color:#fecaca;box-shadow:none}.detail-logout{display:inline-flex;align-items:center;gap:.35rem;color:#ffffffa6;font-size:13px;text-decoration:none;padding:.35rem .75rem;border-radius:7px;background:#ffffff14;border:1px solid rgba(255,255,255,.18);transition:background .12s,color .12s}.detail-logout:hover{color:#ffffffe6;background:#ffffff2e}.detail-hero{margin-bottom:0}.detail-title{margin:0 0 .3rem;font-size:1.65rem;font-weight:700;color:#fff;line-height:1.15;letter-spacing:-.02em}.detail-description{margin:.25rem 0 .75rem;color:#ffffffbf;font-size:14px;line-height:1.5}.detail-meta{display:flex;flex-wrap:wrap;gap:.45rem}.detail-meta-chip{display:inline-flex;align-items:center;gap:.3rem;padding:.22rem .65rem;background:#ffffff26;border:1px solid rgba(255,255,255,.25);border-radius:99px;font-size:11px;font-weight:600;color:#ffffffe6;letter-spacing:.02em}.detail-meta-chip svg{color:#ffffff8c}.detail-meta-owner{background:#fff3;border-color:#ffffff52;color:#fffffff2}.detail-meta-owner svg{color:#fff9}.detail-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.75rem;margin-bottom:1.5rem}.detail-stat{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;background:#f8faff;border:1px solid #e9eef8;border-radius:12px;transition:border-color .12s,box-shadow .12s,transform .12s}.detail-stat:hover{border-color:#c7d7f7;box-shadow:0 2px 8px #2563eb14;transform:translateY(-1px)}.detail-stat-icon{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;flex-shrink:0;border:1px solid transparent}.detail-stat-body{display:flex;flex-direction:column;gap:.1rem;min-width:0;flex:1}.detail-stat-label{font-size:11px;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.06em}.detail-stat-value{font-size:1.35rem;font-weight:700;color:#0f172a;line-height:1.1;letter-spacing:-.01em}.detail-stat-value-sm{font-size:.95rem;font-weight:600}.detail-error{background:#fef2f2;border:1px solid #fecaca;border-radius:6px;color:#dc2626;padding:.65rem 1rem;font-size:13px;margin-bottom:1.25rem}.detail-section{background:#f8faff;border:1px solid #e9eef8;border-radius:14px;padding:1.25rem 1.5rem;margin-bottom:1rem}.detail-section-title{display:inline-flex;align-items:center;gap:.45rem;margin:0 0 1rem;font-size:12px;font-weight:700;color:#475569;text-transform:uppercase;letter-spacing:.08em}.detail-section .field{margin-bottom:.6rem}.detail-section .horizontal-group{gap:.75rem}.detail-section .textarea{min-height:56px}.detail-section-title svg{color:#3b82f6}.detail-section .field label{display:inline-flex;align-items:center;gap:.35rem}.detail-section .field label svg{color:#94a3b8}.detail-form-footer{display:flex;align-items:center;justify-content:flex-end;gap:.75rem;min-height:2rem;margin-top:.5rem}.detail-save-success{display:inline-flex;align-items:center;gap:.35rem;color:#16a34a;font-size:13px;font-weight:500;animation:fade-in .2s ease-out}@keyframes fade-in{0%{opacity:0;transform:translateY(2px)}to{opacity:1;transform:translateY(0)}}.edit-modal-form .field{margin-bottom:.6rem}.edit-modal-form .horizontal-group{gap:.75rem}.edit-modal-form .field label{display:inline-flex;align-items:center;gap:.35rem}.edit-modal-form .field label svg{color:#94a3b8}.edit-modal-form .textarea{min-height:56px}.detail-dl{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem 1.5rem;margin:0}.detail-dl div{display:flex;flex-direction:column;gap:.25rem}.detail-dl-full{grid-column:1 / -1}.detail-dl dt{display:inline-flex;align-items:center;gap:.3rem;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#94a3b8}.detail-dl dt svg{color:#cbd5e1}.detail-dl dd{margin:0;font-size:14px;color:#334155}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;font-size:14px;color:#334155;margin:0;padding:0;box-sizing:border-box;background:linear-gradient(160deg,#0f172a,#1e1b4b 55%,#0f172a);background-attachment:fixed;min-height:100vh}h1,h2,h3,h4,h5,h6{color:#0f172a}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}table{width:100%;border-collapse:collapse}th,td{padding:.75rem 1rem;text-align:left}th{background-color:transparent;color:#64748b;font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.1em;padding-bottom:.6rem;border-bottom:2px solid #e2e8f0}th:hover .sort-icon{opacity:1!important;color:#3b82f6!important;transform:scale(1.2)}td{border-bottom:1px solid #f1f5f9}tbody tr{transition:background-color .1s ease-in-out}tbody tr:last-child td{border-bottom:none}tbody tr:hover{background-color:#f5f9ff}.table-responsive{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}.page-container{padding:2.5rem 2rem;max-width:1200px;margin:0 auto}.card-container{background-color:#fff;border-radius:20px;overflow:hidden;box-shadow:0 4px 6px -1px #00000040,0 20px 60px -10px #00000073,0 0 0 1px #ffffff0f;border:none}.card-body{padding:2rem}@media(max-width:600px){.page-container{padding:.75rem}.card-body{padding:1rem}}.button-group{display:flex;align-items:center;gap:.5rem;justify-content:flex-end;margin-top:1rem}.deployment-badge-wrapper .deployment-tooltip{visibility:hidden;opacity:0;position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%);background-color:#fff;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);color:#334155;font-size:12px;font-weight:500;padding:.35rem .6rem;border-radius:4px;white-space:nowrap;box-shadow:0 2px 8px #0000001a;border:1px solid rgba(0,0,0,.05);pointer-events:none;transition:opacity .12s ease-in-out,visibility .12s ease-in-out;z-index:10}.deployment-badge-wrapper .deployment-tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border-width:4px;border-style:solid;border-color:#ffffff transparent transparent transparent}.deployment-badge-wrapper:hover .deployment-tooltip{visibility:visible;opacity:1}
