body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}#root{min-height:100vh}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f5f7fa;color:#2c3e50}.app{max-width:1200px;margin:0 auto;padding:20px}.header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;padding:20px 0;border-bottom:2px solid #e1e8ed}.header h1{font-size:28px;color:#1a202c}.header-actions{display:flex;gap:10px}.create-env-btn{background:#48bb78;color:#fff;border:none;padding:10px 20px;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:background .2s}.create-env-btn:hover{background:#38a169}.refresh-btn{background:#4299e1;color:#fff;border:none;padding:10px 20px;border-radius:6px;font-size:14px;cursor:pointer;transition:background .2s}.refresh-btn:hover{background:#3182ce}.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:30px}.stat-card{background:#fff;padding:20px;border-radius:8px;box-shadow:0 1px 3px #0000001a;text-align:center}.stat-value{font-size:36px;font-weight:700;color:#4299e1;margin-bottom:8px}.stat-label{font-size:14px;color:#718096;text-transform:uppercase;letter-spacing:.5px}.environments{display:flex;flex-direction:column;gap:15px}.env-card{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;overflow:hidden;transition:box-shadow .2s}.env-card:hover{box-shadow:0 4px 6px #00000026}.env-card.env-disabled{opacity:.7;background:#f5f5f5}.env-card.env-disabled .env-header{background:#fafafa}.disabled-badge{display:inline-block;margin-left:12px;padding:3px 10px;background:#fbbf24;color:#78350f;font-size:11px;font-weight:700;text-transform:uppercase;border-radius:10px;vertical-align:middle}.env-header{padding:20px;display:flex;justify-content:space-between;align-items:center;gap:15px;transition:background .2s}.env-header:hover{background:#f7fafc}.env-header-main{flex:1;cursor:pointer;display:flex;justify-content:space-between;align-items:center}.env-header h3{font-size:18px;color:#2d3748;margin:0}.env-actions{display:flex;gap:8px}.btn-enable-env{background:#48bb78;color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:13px;cursor:pointer;transition:all .2s;white-space:nowrap}.btn-enable-env:hover{background:#38a169;transform:translateY(-1px);box-shadow:0 2px 4px #0003}.btn-disable-env{background:#ed8936;color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:13px;cursor:pointer;transition:all .2s;white-space:nowrap}.btn-disable-env:hover{background:#dd6b20;transform:translateY(-1px);box-shadow:0 2px 4px #0003}.btn-delete-env{background:#fc8181;color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:13px;cursor:pointer;transition:all .2s;white-space:nowrap}.btn-delete-env:hover{background:#f56565;transform:translateY(-1px);box-shadow:0 2px 4px #0003}.env-meta{display:flex;align-items:center;gap:15px}.badge{background:#edf2f7;color:#4a5568;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600;text-transform:uppercase}.service-count{font-size:14px;color:#718096}.toggle{font-size:12px;color:#a0aec0}.services{border-top:1px solid #e2e8f0;padding:10px 20px 20px;background:#f7fafc}.service-item{padding:15px;background:#fff;border-radius:6px;margin-bottom:10px;border:1px solid #e2e8f0;transition:all .2s}.service-item:has(.patched-badge){border-left:3px solid #48bb78;background:#f0fff4}.service-item:last-child{margin-bottom:0}.service-header-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;gap:10px}.service-name{font-weight:600;color:#2d3748;display:flex;align-items:center;gap:10px;flex:1}.service-actions{display:flex;gap:8px}.patched-badge{background:#48bb78;color:#fff;padding:3px 10px;border-radius:4px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.service-details{display:flex;flex-direction:column;gap:6px}.tag-info{display:flex;align-items:center;gap:8px;font-size:13px}.tag-info .label{color:#718096;font-weight:500;min-width:60px}.tag-info code{background:#edf2f7;padding:3px 8px;border-radius:4px;font-family:Monaco,Courier New,monospace;font-size:12px;color:#2d3748}.service-item:not(:has(.patched-badge)) .tag-info code{opacity:.7}.service-item:not(:has(.patched-badge)) .service-name{opacity:.85}.loading,.error,.empty{text-align:center;padding:60px 20px;color:#718096;font-size:16px}.error{color:#e53e3e}button{font-family:inherit}button:active{transform:translateY(1px)}.btn-add,.btn-remove{padding:6px 12px;border:none;border-radius:4px;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s}.btn-add{background:#4299e1;color:#fff}.btn-add:hover{background:#3182ce}.btn-remove{background:#fc8181;color:#fff}.btn-remove:hover{background:#f56565}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;padding:20px}.modal{background:#fff;border-radius:8px;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.modal-small{max-width:450px}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e2e8f0}.modal-header h2{font-size:20px;color:#1a202c;margin:0}.close-btn{background:none;border:none;font-size:28px;color:#a0aec0;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.close-btn:hover{background:#edf2f7;color:#2d3748}.modal form{padding:24px}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-weight:500;color:#2d3748;font-size:14px}.required{color:#e53e3e}.optional{color:#718096;font-weight:400}.pattern-mode-selector{display:flex;gap:20px;margin-bottom:12px;padding:12px;background:#f7fafc;border-radius:6px}.radio-label{display:flex;align-items:center;gap:6px;cursor:pointer;font-size:14px;color:#2d3748}.radio-label input[type=radio]{width:auto;cursor:pointer;margin:0}.radio-label span{-webkit-user-select:none;user-select:none}.form-group input{width:100%;padding:10px 12px;border:1px solid #e2e8f0;border-radius:6px;font-size:14px;font-family:inherit;transition:border-color .2s}.form-group input[type=text],.form-group input[type=password]{width:100%}.form-group input:focus{outline:none;border-color:#4299e1;box-shadow:0 0 0 3px #4299e11a}.input-disabled{background:#edf2f7;color:#718096;cursor:not-allowed}.help-text{display:block;margin-top:6px;font-size:12px;color:#718096;line-height:1.4}.modal-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:24px;padding-top:20px;border-top:1px solid #e2e8f0}.btn-cancel,.btn-submit{padding:10px 20px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.btn-cancel{background:#edf2f7;color:#4a5568}.btn-cancel:hover{background:#e2e8f0}.btn-submit{background:#48bb78;color:#fff}.btn-submit:hover{background:#38a169}@media(max-width:768px){.app{padding:15px}.header{flex-direction:column;gap:15px;align-items:flex-start}.header h1{font-size:24px}.stats{grid-template-columns:repeat(2,1fr)}.env-header{flex-direction:column;align-items:flex-start;gap:10px}.env-meta{width:100%;justify-content:space-between}.tag-info{flex-direction:column;align-items:flex-start}.service-header-row{flex-direction:column;align-items:flex-start;gap:8px}.service-actions,.btn-add,.btn-remove{width:100%}.modal{max-height:95vh}.modal-actions{flex-direction:column-reverse}.btn-cancel,.btn-submit{width:100%}.pattern-mode-selector{flex-direction:column;gap:10px}}
