:root{--color-primary: #2563EB;--color-secondary: #64748B;--color-accent: #7C3AED;--color-bg-main: #F8FAFC;--color-surface: #FFFFFF;--color-text-primary: #0F172A;--color-text-secondary: #475569;--color-text-disabled: #94A3B8;--color-success: #10B981;--color-error: #EF4444;--color-warning: #F59E0B;--color-info: #3B82F6;--color-border: #E2E8F0;--color-border-focus: var(--color-primary);--color-slate-100: #F1F5F9;--color-slate-200: #E2E8F0;--color-slate-700: #334155;--font-family: "Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-size-h1: 2.25rem;--font-size-h2: 1.5rem;--font-size-h3: 1.25rem;--font-size-body: 1rem;--font-size-small: .875rem;--line-height-body: 1.5;--line-height-heading: 1.2;--letter-spacing-h1: -.025em;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--spacing-2xl: 48px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--transition-fast: .15s ease;--transition-base: .2s ease}*{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-family);font-size:var(--font-size-body);line-height:var(--line-height-body);color:var(--color-text-primary);background-color:var(--color-bg-main);min-height:100vh}h1{font-size:var(--font-size-h1);font-weight:700;line-height:var(--line-height-heading);letter-spacing:var(--letter-spacing-h1);color:var(--color-text-primary)}h2{font-size:var(--font-size-h2);font-weight:600;line-height:var(--line-height-heading);color:var(--color-text-primary)}h3{font-size:var(--font-size-h3);font-weight:500;line-height:var(--line-height-heading);color:var(--color-text-primary)}p{color:var(--color-text-secondary)}small,.text-small{font-size:var(--font-size-small);font-weight:500;color:var(--color-text-secondary)}.container{width:100%;max-width:1200px;margin:0 auto;padding:0 var(--spacing-lg)}.container-narrow{max-width:800px}.container-login{max-width:450px}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.btn{display:inline-flex;align-items:center;justify-content:center;padding:var(--spacing-sm) var(--spacing-md);font-family:var(--font-family);font-size:var(--font-size-body);font-weight:500;line-height:1.5;text-align:center;text-decoration:none;border:1.5px solid transparent;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-base);white-space:nowrap;-webkit-user-select:none;user-select:none;min-height:44px}.btn:focus{outline:none;box-shadow:0 0 0 4px #2563eb33}.btn:disabled{opacity:.6;cursor:not-allowed;pointer-events:none}.btn-primary{background-color:var(--color-primary);color:#fff}.btn-primary:hover:not(:disabled){background-color:#1d4ed8}.btn-secondary{background-color:var(--color-slate-100);color:var(--color-slate-700);border-color:var(--color-slate-200)}.btn-secondary:hover:not(:disabled){background-color:var(--color-slate-200)}.btn-ghost{background-color:transparent;color:var(--color-primary);border:none;text-decoration:underline;text-underline-offset:4px}.btn-ghost:hover:not(:disabled){background-color:var(--color-slate-100)}.btn-full{width:100%}.btn-lg{padding:var(--spacing-md) var(--spacing-lg);font-size:var(--font-size-h3)}.btn-sm{padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--font-size-small);min-height:32px}.btn-danger{background-color:var(--color-error);color:#fff;border:1px solid var(--color-error)}.btn-danger:hover:not(:disabled){background-color:#dc2626;border-color:#dc2626}.btn-danger:disabled{opacity:.5;cursor:not-allowed}.btn-loading{position:relative;color:transparent;pointer-events:none}.btn-loading:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:20px;height:20px;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:translate(-50%,-50%) rotate(360deg)}}.form-group{margin-bottom:var(--spacing-lg)}.form-label{display:block;margin-bottom:var(--spacing-sm);font-size:var(--font-size-small);font-weight:500;color:var(--color-text-primary)}.form-label.required:after{content:" *";color:var(--color-error)}.form-input,.form-select{width:100%;padding:var(--spacing-sm) var(--spacing-md);font-family:var(--font-family);font-size:var(--font-size-body);line-height:var(--line-height-body);color:var(--color-text-primary);background-color:var(--color-surface);border:1.5px solid var(--color-border);border-radius:var(--radius-sm);transition:all var(--transition-base);min-height:44px}.form-input:focus,.form-select:focus{outline:none;border-color:var(--color-border-focus);box-shadow:0 0 0 4px #2563eb1a}.form-input:disabled,.form-select:disabled{background-color:var(--color-slate-100);cursor:not-allowed;opacity:.6}.form-input-error,.form-select-error{border-color:var(--color-error)}.form-input-error:focus,.form-select-error:focus{box-shadow:0 0 0 4px #ef44441a}.form-error-message{display:block;margin-top:var(--spacing-xs);font-size:var(--font-size-small);color:var(--color-error)}.form-help-text{display:block;margin-top:var(--spacing-xs);font-size:var(--font-size-small);color:var(--color-text-secondary)}.password-input-wrapper{position:relative}.password-toggle{position:absolute;right:var(--spacing-md);top:50%;transform:translateY(-50%);background:none;border:none;color:var(--color-text-secondary);cursor:pointer;padding:var(--spacing-xs);display:flex;align-items:center;justify-content:center;min-width:32px;min-height:32px;border-radius:var(--radius-sm);transition:background-color var(--transition-fast)}.password-toggle:hover{background-color:var(--color-slate-100)}.password-toggle:focus{outline:none;box-shadow:0 0 0 2px var(--color-primary)}.password-toggle-icon{display:block;width:20px;height:20px;position:relative}.checkbox-wrapper{display:flex;align-items:center;gap:var(--spacing-sm);cursor:pointer}.checkbox-input{width:18px;height:18px;margin:0;cursor:pointer;accent-color:var(--color-primary)}.checkbox-label{margin:0;font-size:var(--font-size-body);cursor:pointer;-webkit-user-select:none;user-select:none}.select-wrapper{position:relative}.select-wrapper:after{content:"▼";position:absolute;right:var(--spacing-md);top:50%;transform:translateY(-50%);pointer-events:none;color:var(--color-text-secondary);font-size:12px}.form-select{appearance:none;padding-right:calc(var(--spacing-md) * 2 + 16px);cursor:pointer}.card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-lg);box-shadow:var(--shadow-sm)}.card-elevated{box-shadow:var(--shadow-md)}.card-modal{box-shadow:var(--shadow-lg)}.alert{padding:var(--spacing-md);border-radius:var(--radius-sm);margin-bottom:var(--spacing-lg)}.alert-error{background-color:#ef44441a;border:1px solid var(--color-error);color:var(--color-error)}.alert-success{background-color:#10b9811a;border:1px solid var(--color-success);color:var(--color-success)}.badge{display:inline-flex;align-items:center;padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--font-size-small);font-weight:500;border-radius:9999px}.badge-pending{background-color:#3b82f61a;color:var(--color-info)}.badge-processing{background-color:#f59e0b1a;color:var(--color-warning)}.badge-done{background-color:#10b9811a;color:var(--color-success)}.badge-error{background-color:#ef44441a;color:var(--color-error)}.error-message{padding:var(--spacing-md);border-radius:var(--radius-sm);margin-bottom:var(--spacing-lg);background-color:#ef44441a;border:1px solid var(--color-error);color:var(--color-error);font-weight:500;display:block}.navbar{background-color:var(--color-surface);border-bottom:1px solid var(--color-border);padding:var(--spacing-md) var(--spacing-lg);box-shadow:var(--shadow-sm)}.navbar-content{display:flex;justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto}.navbar-brand{font-size:var(--font-size-h3);font-weight:600;color:var(--color-text-primary);text-decoration:none}.navbar-user{display:flex;align-items:center;gap:var(--spacing-md)}.user-info{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--font-size-small);color:var(--color-text-secondary)}.deployment-type-selector{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background-color:#2563eb0d;border:1px solid var(--color-border);border-radius:var(--radius-sm)}.deployment-type-label{font-size:var(--font-size-small);font-weight:500;color:var(--color-text-secondary);margin:0;white-space:nowrap}.deployment-type-select{padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--font-size-small);border:1px solid var(--color-border);border-radius:var(--radius-sm);background-color:var(--color-surface);color:var(--color-text-primary);cursor:pointer;transition:all var(--transition-base);min-width:140px}.deployment-type-select:hover{border-color:var(--color-primary);background-color:var(--color-slate-100)}.deployment-type-select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #2563eb1a}.deployment-type-select option{background-color:var(--color-surface);color:var(--color-text-primary);padding:var(--spacing-sm)}.main-content{padding:var(--spacing-2xl) var(--spacing-lg);min-height:calc(100vh - 80px)}.main-content-centered{display:flex;align-items:center;justify-content:center}.login-container{width:100%;max-width:450px;padding:var(--spacing-lg)}.login-card{text-align:center}.login-logo{width:64px;height:64px;margin:0 auto var(--spacing-lg);background-color:var(--color-primary);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:#fff;font-size:32px;font-weight:700}.login-title{margin-bottom:var(--spacing-md)}.login-subtitle{margin-bottom:var(--spacing-2xl);color:var(--color-text-secondary)}.wizard-step{display:none}.wizard-step.active{display:block}.step-title{margin-bottom:var(--spacing-md)}.step-description{margin-bottom:var(--spacing-xl);color:var(--color-text-secondary)}.url-preview-card{background-color:var(--color-slate-100);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:var(--spacing-md);margin-top:var(--spacing-md)}.url-preview-item{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm) 0}.url-preview-item:not(:last-child){border-bottom:1px solid var(--color-border)}.url-label{font-size:var(--font-size-small);font-weight:500;color:var(--color-text-secondary)}.url-value{font-family:Courier New,monospace;font-size:var(--font-size-small);color:var(--color-primary);word-break:break-all}.input-with-suffix{display:flex;align-items:center;border:1.5px solid var(--color-border);border-radius:var(--radius-sm);background-color:var(--color-surface);overflow:hidden;transition:all var(--transition-base)}.input-with-suffix:focus-within{border-color:var(--color-border-focus);box-shadow:0 0 0 4px #2563eb1a}.input-with-suffix .form-input{border:none;box-shadow:none;flex:1}.input-with-suffix:focus-within .form-input{box-shadow:none}.input-suffix{padding:0 var(--spacing-md);font-size:var(--font-size-body);color:var(--color-text-secondary);white-space:nowrap;background-color:var(--color-slate-100);border-left:1px solid var(--color-border)}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:none;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-lg)}.modal-overlay.active{display:flex}.modal-content{width:100%;max-width:500px;background-color:var(--color-surface);border-radius:var(--radius-md);padding:var(--spacing-xl);box-shadow:var(--shadow-lg);position:relative;max-height:90vh;overflow-y:auto}.modal-header{margin-bottom:var(--spacing-lg)}.modal-title{margin-bottom:var(--spacing-sm)}.modal-close{position:absolute;top:var(--spacing-lg);right:var(--spacing-lg);background:none;border:none;font-size:24px;color:var(--color-text-secondary);cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:background-color var(--transition-fast)}.modal-close:hover{background-color:var(--color-slate-100)}.modal-close:focus{outline:none;box-shadow:0 0 0 2px var(--color-primary)}.confirmation-table{width:100%;border-collapse:collapse;margin:var(--spacing-lg) 0;background-color:var(--color-slate-100);border-radius:var(--radius-sm);overflow:hidden}.confirmation-table td{padding:var(--spacing-md);border-bottom:1px solid var(--color-border)}.confirmation-table tr:last-child td{border-bottom:none}.confirmation-table .table-label{font-weight:500;width:40%}.confirmation-table .table-value{font-family:Courier New,monospace;color:var(--color-text-primary)}.modal-actions{display:flex;gap:var(--spacing-md);margin-top:var(--spacing-xl)}.modal-actions .btn{flex:1}.progress-header{margin-bottom:var(--spacing-xl)}.progress-bar-container{width:100%;height:8px;background-color:var(--color-slate-200);border-radius:9999px;overflow:hidden;margin-top:var(--spacing-md)}.progress-bar{height:100%;background-color:var(--color-primary);transition:width .3s ease;border-radius:9999px}.progress-text{text-align:center;margin-top:var(--spacing-sm);font-size:var(--font-size-small);color:var(--color-text-secondary)}.task-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.task-card{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-lg);background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:all var(--transition-base)}.task-card.processing{border-color:var(--color-warning);background-color:#f59e0b0d}.task-card.done{border-color:var(--color-success);background-color:#10b9810d}.task-card.error{border-color:var(--color-error);background-color:#ef44440d}.task-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;flex-shrink:0;font-size:20px}.task-icon.pending{background-color:#3b82f61a;color:var(--color-info)}.task-icon.processing{background-color:#f59e0b1a;color:var(--color-warning);animation:pulse 2s ease-in-out infinite}.task-icon.done{background-color:#10b9811a;color:var(--color-success)}.task-icon.error{background-color:#ef44441a;color:var(--color-error)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.task-spinner{width:20px;height:20px;border:2px solid var(--color-warning);border-top-color:transparent;border-radius:50%;animation:spin .6s linear infinite}.task-content{flex:1}.task-title{font-weight:500;margin-bottom:var(--spacing-xs)}.task-description{font-size:var(--font-size-small);color:var(--color-text-secondary)}.task-status{margin-left:auto}.task-actions{display:flex;gap:var(--spacing-sm)}.success-container{max-width:600px;margin:0 auto;text-align:center}.success-icon{width:80px;height:80px;margin:0 auto var(--spacing-xl);background-color:#10b9811a;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--color-success);font-size:48px;font-weight:700}.success-title{margin-bottom:var(--spacing-md)}.success-description{margin-bottom:var(--spacing-2xl);color:var(--color-text-secondary)}.link-cards{display:flex;flex-direction:column;gap:var(--spacing-md);margin-bottom:var(--spacing-xl)}.link-card{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-lg);background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);text-decoration:none;color:var(--color-text-primary);transition:all var(--transition-base)}.link-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-md);transform:translateY(-2px)}.link-card-content{flex:1;text-align:left}.link-card-label{font-size:var(--font-size-small);font-weight:500;color:var(--color-text-secondary);margin-bottom:var(--spacing-xs)}.link-card-url{font-family:Courier New,monospace;font-size:var(--font-size-body);color:var(--color-primary);word-break:break-all}.link-card-actions{display:flex;gap:var(--spacing-sm);margin-left:var(--spacing-md)}.btn-icon{width:36px;height:36px;padding:0;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);background-color:var(--color-slate-100);color:var(--color-text-secondary);border:none;cursor:pointer;transition:all var(--transition-fast)}.btn-icon:hover{background-color:var(--color-slate-200);color:var(--color-primary)}.btn-icon:focus{outline:none;box-shadow:0 0 0 2px var(--color-primary)}.copy-toast{position:fixed;bottom:var(--spacing-xl);left:50%;transform:translate(-50%) translateY(100px);padding:var(--spacing-md) var(--spacing-lg);background-color:var(--color-text-primary);color:#fff;border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);opacity:0;transition:all var(--transition-base);z-index:2000}.copy-toast.show{transform:translate(-50%) translateY(0);opacity:1}@media(max-width:640px){:root{--font-size-h1: 1.875rem;--font-size-h2: 1.25rem}.container{padding:0 var(--spacing-md)}.main-content{padding:var(--spacing-lg) var(--spacing-md)}.navbar-content{flex-direction:column;gap:var(--spacing-md);align-items:flex-start}.modal-content{padding:var(--spacing-lg)}.task-card{flex-wrap:wrap}.task-status{margin-left:0;width:100%;margin-top:var(--spacing-sm)}.link-card{flex-direction:column;align-items:flex-start}.link-card-actions{margin-left:0;margin-top:var(--spacing-sm);width:100%;justify-content:flex-end}}.text-center{text-align:center}.mt-lg{margin-top:var(--spacing-lg)}.mt-xl{margin-top:var(--spacing-xl)}.mb-lg{margin-bottom:var(--spacing-lg)}.mb-xl{margin-bottom:var(--spacing-xl)}.hidden{display:none!important}.deployments-table{width:100%;border-collapse:collapse;margin-top:var(--spacing-lg)}.deployments-table th{text-align:left;padding:var(--spacing-md);border-bottom:2px solid var(--color-border);font-weight:600;color:var(--color-text-primary);background-color:var(--color-slate-100)}.deployments-table td{padding:var(--spacing-md);border-bottom:1px solid var(--color-border);color:var(--color-text-primary)}.deployments-table tbody tr:hover{background-color:var(--color-slate-100)}.deployments-table tbody tr:last-child td{border-bottom:none}.deployment-card{border:1px solid var(--color-border);border-radius:var(--radius-md);margin-bottom:var(--spacing-md);background-color:var(--color-surface);transition:box-shadow var(--transition-base)}.deployment-card:hover{box-shadow:var(--shadow-md)}.deployment-progress-section{padding:var(--spacing-md);background-color:#f59e0b0d;border-bottom:1px solid var(--color-border)}.progress-bar-container{width:100%;height:8px;background-color:#f59e0b1a;border-radius:4px;overflow:hidden;margin-bottom:var(--spacing-sm)}.progress-bar{height:100%;background-color:var(--color-warning);transition:width .3s ease;border-radius:4px}.progress-info{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md);flex-wrap:wrap}.progress-percentage{font-weight:600;color:var(--color-warning);font-size:var(--font-size-small);min-width:50px}.progress-step{color:var(--color-text-secondary);font-size:var(--font-size-small);flex:1;display:flex;align-items:center;gap:var(--spacing-xs)}.progress-step-indicator{animation:spin 2s linear infinite;display:inline-block}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.deployment-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md);cursor:pointer;border-bottom:1px solid var(--color-border)}.deployment-header:hover{background-color:var(--color-slate-100)}.deployment-header-main{display:flex;align-items:center;gap:var(--spacing-md);flex:1}.deployment-expand-icon{font-size:12px;color:var(--color-text-secondary);width:20px;text-align:center}.deployment-summary{display:flex;align-items:center;gap:var(--spacing-lg);flex-wrap:wrap}.deployment-id{font-weight:600;color:var(--color-text-primary)}.deployment-prefix{color:var(--color-text-secondary)}.deployment-date{color:var(--color-text-secondary);font-size:var(--font-size-small)}.deployment-actions,.delete-buttons-group{display:flex;gap:var(--spacing-sm);flex-wrap:wrap}.deployment-details{padding:var(--spacing-lg);background-color:var(--color-slate-100);border-top:1px solid var(--color-border)}.deployment-section{margin-bottom:var(--spacing-lg);padding:var(--spacing-md);background-color:var(--color-surface);border-radius:var(--radius-sm);border:1px solid var(--color-border)}.deployment-section:last-child{margin-bottom:0}.deployment-section-title{font-size:var(--font-size-h3);font-weight:600;margin-bottom:var(--spacing-md);color:var(--color-text-primary)}.deployment-status-deleted{color:var(--color-error);font-weight:500;margin:0}.credential-group{display:flex;flex-direction:column;gap:var(--spacing-md)}.credential-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm);background-color:var(--color-slate-100);border-radius:var(--radius-sm)}.credential-key{font-weight:500;color:var(--color-text-secondary);min-width:120px}.credential-value{font-family:Courier New,monospace;color:var(--color-text-primary);flex:1;word-break:break-all}.copy-btn{flex-shrink:0;cursor:pointer;background:none;border:none;font-size:16px;padding:var(--spacing-xs);transition:transform var(--transition-fast)}.copy-btn:hover{transform:scale(1.1)}.deployment-error-section{background-color:#ef44440d;border-color:var(--color-error)}.deployment-error-message{color:var(--color-error);font-weight:500;margin:0 0 var(--spacing-sm) 0}.deployment-error-detail{color:var(--color-text-secondary);font-size:var(--font-size-small);margin:var(--spacing-xs) 0}
