: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}}.deployment-card{background:#fff;border-radius:12px;padding:clamp(16px,3vw,24px);box-shadow:0 2px 4px #0000001a;transition:box-shadow .3s ease}.deployment-card.minimal-view{padding:clamp(12px,2vw,16px);border-radius:8px}.deployment-card.disabled{opacity:.7;background:#f9f9f9}.deployment-card.locked{border:2px solid #ff9800;background:#fff8e1}.deployment-card:hover{box-shadow:0 6px 12px #00000026;transform:translateY(-2px);transition:all .3s ease}.deployment-card.disabled:hover{transform:none;box-shadow:0 2px 4px #0000001a}.deployment-card.locked:hover{box-shadow:0 6px 12px #ff980033}@media(hover:none)and (pointer:coarse){.deployment-card{box-shadow:0 2px 6px #0000001f}}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:clamp(12px,2vw,15px);gap:12px;flex-wrap:wrap}.deployment-card.minimal-view .card-header{margin-bottom:clamp(8px,1.5vw,10px)}.card-header h3{margin:0;font-size:clamp(16px,3vw,20px);color:#333;line-height:1.3;flex:1;min-width:0}.deployment-card.minimal-view .card-header h3{font-size:clamp(14px,2.5vw,16px)}.badges{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.badge{padding:5px 14px;border-radius:12px;font-size:clamp(11px,2vw,13px);font-weight:600;text-transform:uppercase;white-space:nowrap;flex-shrink:0}.badge.staging{background:#e3f2fd;color:#1976d2}.badge.production{background:#fff3e0;color:#f57c00}.badge.locked{background:#fafafa;color:#757575;border:1px solid #e0e0e0}.badge.deploying{background:#fff3e0;color:#f57c00;border:1px solid #ff9800;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.card-body{display:flex;flex-direction:column;gap:clamp(10px,2vw,14px)}.deployment-card.minimal-view .card-body{gap:clamp(6px,1.5vw,8px)}.branch-info{margin:0;font-size:clamp(13px,2vw,15px);color:#666;line-height:1.4}.button-group{display:flex;gap:8px;align-items:stretch}.deploy-button{flex:1;padding:14px 24px;border:none;border-radius:8px;font-size:clamp(13px,2.5vw,15px);font-weight:600;cursor:pointer;transition:all .3s ease;color:#fff;min-height:48px;touch-action:manipulation;-webkit-tap-highlight-color:transparent}.deployment-card.minimal-view .deploy-button{padding:10px 16px;font-size:clamp(12px,2vw,14px);min-height:40px;border-radius:6px}.lock-button{padding:14px 20px;border:2px solid #ff9800;border-radius:8px;font-size:clamp(13px,2.5vw,15px);font-weight:600;cursor:pointer;transition:all .3s ease;background:#fff;color:#ff9800;min-height:48px;min-width:90px;touch-action:manipulation;-webkit-tap-highlight-color:transparent}.lock-button:hover:not(:disabled){background:#fff3e0;border-color:#f57c00;color:#f57c00;transform:translateY(-2px);box-shadow:0 4px 8px #ff980033}.lock-button.locked{background:#ff9800;color:#fff}.lock-button.locked:hover:not(:disabled){background:#f57c00;border-color:#f57c00}.lock-button:disabled{opacity:.5;cursor:not-allowed;background:#f5f5f5!important;border-color:#e0e0e0!important;color:#bdbdbd!important}.deploy-button.staging{background:#1976d2}.deploy-button.staging:hover:not(:disabled){background:#1565c0}.deploy-button.production{background:#f57c00}.deploy-button.production:hover:not(:disabled){background:#ef6c00}.deploy-button:disabled{opacity:.5;cursor:not-allowed;background:#bdbdbd!important}.message{padding:10px;border-radius:4px;font-size:13px;animation:slideIn .3s ease}.message.success{background:#e8f5e9;color:#2e7d32;border:1px solid #4caf50}.message.error{background:#ffebee;color:#c62828;border:1px solid #f44336}.message.warning{background:#fff3e0;color:#e65100;border:1px solid #ff9800;font-weight:500}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@media(min-width:1025px){.deployment-card{padding:28px}.card-header{margin-bottom:18px}.card-header h3{font-size:22px}.badge{font-size:14px;padding:6px 16px}.card-body{gap:16px}.branch-info{font-size:16px}.deploy-button{font-size:16px;padding:16px 32px;min-height:54px}.deploy-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 8px #0003}.message{font-size:15px;padding:14px}}@media(max-width:768px){.card-body{gap:10px}.branch-info{font-size:13px}.deploy-button{padding:14px 20px;font-size:14px}}@media(max-width:480px){.deployment-card{padding:16px}.card-header{margin-bottom:12px}.card-header h3{font-size:16px}.badge{font-size:11px;padding:3px 10px}.branch-info{font-size:12px}.message{font-size:12px;padding:8px}}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.login-card{background:#fff;border-radius:16px;padding:48px;box-shadow:0 10px 40px #0000001a;width:100%;max-width:420px}.login-header{text-align:center;margin-bottom:32px}.login-header h1{margin:0 0 8px;font-size:28px;color:#333}.login-subtitle{margin:0;color:#666;font-size:14px}.form-group{margin-bottom:24px}.form-group label{display:block;margin-bottom:8px;font-weight:600;color:#333;font-size:14px}.form-group input{width:100%;padding:12px 16px;border:2px solid #e0e0e0;border-radius:8px;font-size:15px;transition:border-color .3s ease;box-sizing:border-box}.form-group input:focus{outline:none;border-color:#667eea}.form-group input:disabled{background:#f5f5f5;cursor:not-allowed}.error-message{background:#ffebee;color:#c62828;padding:12px 16px;border-radius:8px;margin-bottom:20px;font-size:14px;border:1px solid #ef5350;animation:shake .3s ease}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-10px)}75%{transform:translate(10px)}}.login-button{width:100%;padding:14px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{opacity:.6;cursor:not-allowed}.login-footer{margin-top:24px;text-align:center}.hint{margin:0;font-size:12px;color:#999}@media(max-width:480px){.login-card{padding:32px 24px}.login-header h1{font-size:24px}}.logs-container{max-width:1400px;margin:0 auto;padding:20px}.logs-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;flex-wrap:wrap;gap:16px}.logs-header h2{margin:0;font-size:28px;color:#333}.refresh-button{padding:10px 20px;background:#1976d2;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease}.refresh-button:hover:not(:disabled){background:#1565c0;transform:translateY(-2px)}.refresh-button:disabled{opacity:.6;cursor:not-allowed}.logs-filters{display:flex;gap:12px;margin-bottom:24px;flex-wrap:wrap}.filter-button{padding:10px 20px;background:#fff;color:#666;border:2px solid #e0e0e0;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease}.filter-button:hover{border-color:#1976d2;color:#1976d2}.filter-button.active{background:#1976d2;color:#fff;border-color:#1976d2}.logs-list{display:flex;flex-direction:column;gap:12px}.logs-loading{text-align:center;padding:60px 20px;display:flex;flex-direction:column;align-items:center;gap:20px}.spinner{width:40px;height:40px;border:4px solid #f3f3f3;border-top:4px solid #1976d2;border-radius:50%;animation:spin 1s linear infinite}.logs-empty{text-align:center;padding:60px 20px;background:#fff;border-radius:12px;border:2px dashed #e0e0e0}.logs-empty p{margin:0 0 8px;color:#666;font-size:16px}.logs-empty-hint{font-size:14px;color:#999}.log-entry{display:flex;gap:16px;padding:20px;background:#fff;border-radius:12px;border-left:4px solid;box-shadow:0 2px 4px #00000014;transition:all .3s ease}.log-entry.success{border-left-color:#4caf50}.log-entry.failed{border-left-color:#f44336}.log-entry.in-progress{border-left-color:#ff9800}.log-entry:hover{box-shadow:0 4px 12px #0000001f;transform:translate(4px)}.log-status{flex-shrink:0}.status-icon{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;font-weight:700;font-size:16px}.status-icon.success{background:#e8f5e9;color:#4caf50}.status-icon.failed{background:#ffebee;color:#f44336}.status-icon.in-progress{background:#fff3e0;color:#ff9800}.log-content{flex:1;display:flex;flex-direction:column;gap:8px;min-width:0}.log-main{display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:15px}.log-user{font-weight:600;color:#333}.log-action{color:#666}.log-environment{font-weight:600;color:#1976d2}.log-repo-badge{padding:3px 10px;background:#e3f2fd;color:#1976d2;border-radius:6px;font-size:12px;font-weight:600;text-transform:uppercase}.log-stage-badge{padding:3px 10px;border-radius:6px;font-size:12px;font-weight:600;text-transform:uppercase}.log-stage-badge.staging{background:#e3f2fd;color:#1976d2}.log-stage-badge.production{background:#fff3e0;color:#f57c00}.log-meta{display:flex;align-items:center;gap:16px;flex-wrap:wrap;font-size:13px;color:#999}.log-branch{color:#666}.log-time{font-weight:500;color:#666}.log-timestamp{color:#999}@media(max-width:768px){.logs-header{flex-direction:column;align-items:flex-start}.logs-header h2{font-size:24px}.refresh-button,.logs-filters{width:100%}.filter-button{flex:1;padding:12px}.log-entry{flex-direction:column;gap:12px}.log-main{font-size:14px}.log-meta{font-size:12px;gap:12px}}.user-management{padding:2rem;max-width:1400px;margin:0 auto}.user-management-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.user-management-header h2{margin:0;color:#333}.create-user-form{background:#f9f9f9;border:1px solid #ddd;border-radius:8px;padding:2rem;margin-bottom:2rem}.create-user-form h3{margin-top:0;color:#333}.form-group input,.form-group select{width:100%;padding:.75rem;border:1px solid #ccc;border-radius:4px;font-size:1rem;font-family:inherit}.form-group input:focus,.form-group select:focus{outline:none;border-color:#4a90e2;box-shadow:0 0 0 3px #4a90e21a}.permission-helper{display:block;margin-bottom:1rem;color:#666;font-size:.875rem;font-style:italic}.permission-actions-bar{display:flex;gap:.5rem;margin-bottom:1rem}.permissions-grid{overflow-x:auto;border:1px solid #e0e0e0;border-radius:4px;background:#fff;margin-bottom:1rem}.permissions-table{width:100%;border-collapse:collapse;font-size:.9rem}.permissions-table thead{background:#f8f9fa;border-bottom:2px solid #dee2e6}.permissions-table th{padding:.75rem;text-align:left;font-weight:600;color:#555;font-size:.875rem;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.permissions-table th:first-child{min-width:150px}.permissions-table th:nth-child(2){min-width:180px}.permissions-table th:nth-child(3),.permissions-table th:nth-child(4),.permissions-table th:nth-child(5){text-align:center;width:80px}.permissions-table tbody tr{border-bottom:1px solid #f0f0f0;transition:background-color .2s}.permissions-table tbody tr:hover{background:#f8f9fa}.permissions-table td{padding:.75rem;color:#333}.env-name{font-weight:600;color:#333}.env-stages{display:flex;gap:.5rem;flex-wrap:wrap}.stage-badge{display:inline-block;padding:.25rem .5rem;background:#e9ecef;color:#495057;border-radius:3px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.stage-badge.stage-dev{background:#d1ecf1;color:#0c5460;border:1px solid #bee5eb}.stage-badge.stage-staging{background:#fff3cd;color:#856404;border:1px solid #ffeaa7}.stage-badge.stage-prod{background:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.action-cell{text-align:center;vertical-align:middle}.checkbox-label{display:inline-flex;align-items:center;justify-content:center;cursor:pointer;position:relative;margin:0}.checkbox-label input[type=checkbox]{cursor:pointer;width:18px;height:18px;margin:0}.checkbox-label .partial-indicator{position:absolute;color:#4a90e2;font-size:1.5rem;pointer-events:none;margin-left:2px}.checkbox-label input.partial-check{accent-color:#4a90e2}.permission-summary{padding:.75rem;background:#f8f9fa;border-radius:4px;text-align:center;color:#555}.btn:disabled{opacity:.5;cursor:not-allowed}.users-list{margin-top:2rem}.users-list h3{margin-bottom:1rem;color:#333}.users-table{background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 1px 3px #0000001a}.users-table table{width:100%;border-collapse:collapse}.users-table thead{background:#f8f9fa;border-bottom:2px solid #dee2e6}.users-table th{padding:1rem;text-align:left;font-weight:600;color:#555;font-size:.875rem;text-transform:uppercase;letter-spacing:.5px}.users-table td{padding:1rem;border-bottom:1px solid #f0f0f0;color:#333;font-size:.95rem}.users-table tbody tr:hover{background:#f8f9fa}.users-table tbody tr:last-child td{border-bottom:none}.badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-left:.5rem}.badge-success{background:#d4edda;color:#155724}.badge-default{background:#e2e3e5;color:#383d41}.badge-info{background:#d1ecf1;color:#0c5460}.loading{text-align:center;padding:3rem;color:#666;font-size:1.1rem}.text-muted{color:#999;font-style:italic}@media(max-width:768px){.user-management{padding:1rem}.user-management-header{flex-direction:column;gap:1rem;align-items:flex-start}.permission-filters{flex-direction:column}.filter-group{width:100%}.users-table{overflow-x:auto}.users-table table{min-width:600px}}.edit-user-modal{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center}.modal-overlay{position:absolute;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{position:relative;background:#fff;border-radius:12px;padding:2rem;max-width:900px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d;z-index:10000}.modal-content h3{margin-top:0;margin-bottom:1.5rem;color:#333;font-size:1.5rem}.input-disabled{background-color:#f5f5f5;color:#999;cursor:not-allowed}.form-hint{display:block;margin-top:.5rem;color:#777;font-size:.875rem;font-style:italic}.auto-unlock-indicator{margin-left:4px;font-size:10px;color:#28a745;font-weight:700;-webkit-user-select:none;user-select:none}@media(max-width:768px){.modal-content{width:95%;padding:1.5rem;max-height:95vh}}.environment-management{padding:2rem;max-width:1400px;margin:0 auto}.environment-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;gap:2rem}.environment-header h2{margin:0 0 .5rem;color:#333}.subtitle{color:#666;font-size:.95rem;margin:0}.create-env-form{background:#f9f9f9;border:1px solid #ddd;border-radius:8px;padding:2rem;margin-bottom:2rem}.create-env-form h3{margin-top:0;color:#333}.form-row{display:grid;grid-template-columns:2fr 1fr;gap:1rem;margin-bottom:1rem}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:600;color:#555}.form-group .required{color:#dc3545}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.75rem;border:1px solid #ccc;border-radius:4px;font-size:1rem;font-family:inherit}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#4a90e2;box-shadow:0 0 0 3px #4a90e21a}.form-group small{display:block;margin-top:.5rem;color:#777;font-size:.875rem}.env-preview{padding:1rem;background:#fff;border:2px dashed #4a90e2;border-radius:4px;margin-bottom:1.5rem;font-size:.95rem}.env-preview code{background:#e7f3ff;padding:.25rem .5rem;border-radius:3px;font-family:Courier New,monospace;color:#06c;font-weight:600}.permissions-info{background:#e7f3ff;border-left:4px solid #4a90e2;padding:1rem;margin-bottom:1.5rem;border-radius:4px}.permissions-info strong{display:block;margin-bottom:.5rem;color:#06c}.permissions-info ul{margin:.5rem 0 0 1.5rem;padding:0}.permissions-info li{margin:.25rem 0;color:#555}.permissions-info code{background:#fff;padding:.2rem .4rem;border-radius:3px;font-size:.9rem;color:#333}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem;padding-top:1rem;border-top:1px solid #e0e0e0}.environments-list{margin-top:3rem}.environments-list>h3{margin-bottom:1.5rem;color:#333}.family-group{margin-bottom:3rem}.family-title{font-size:1.25rem;color:#333;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid #e0e0e0}.env-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.env-card{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:1.5rem;transition:all .2s}.env-card:hover{box-shadow:0 4px 12px #0000001a;border-color:#4a90e2}.env-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.env-name{margin:0 0 .5rem;color:#333;font-size:1.1rem}.env-code{display:inline-block;background:#f5f5f5;padding:.25rem .5rem;border-radius:3px;font-size:.85rem;color:#666;font-family:Courier New,monospace}.stage-badge{padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.stage-dev{background:#d1ecf1;color:#0c5460}.stage-staging{background:#fff3cd;color:#856404}.stage-prod{background:#f8d7da;color:#721c24}.env-description{color:#666;font-size:.9rem;margin:0 0 1rem;line-height:1.4}.env-meta{color:#999;font-size:.85rem;margin-bottom:1rem}.env-actions{display:flex;gap:.5rem;justify-content:flex-end}.btn{padding:.75rem 1.5rem;border:none;border-radius:4px;font-size:1rem;cursor:pointer;transition:all .2s;font-weight:500}.btn:hover{transform:translateY(-1px);box-shadow:0 2px 8px #00000026}.btn-primary{background-color:#4a90e2;color:#fff}.btn-primary:hover{background-color:#357abd}.btn-secondary{background-color:#6c757d;color:#fff}.btn-secondary:hover{background-color:#5a6268}.btn-danger{background-color:#dc3545;color:#fff}.btn-danger:hover{background-color:#c82333}.btn-sm{padding:.5rem 1rem;font-size:.875rem}.alert{padding:1rem;border-radius:4px;margin-bottom:1rem}.alert-error{background-color:#fee;color:#c33;border:1px solid #fcc}.alert-success{background-color:#efe;color:#3c3;border:1px solid #cfc}.loading,.no-data{text-align:center;padding:3rem;color:#666;font-size:1.1rem}@media(max-width:768px){.environment-management{padding:1rem}.environment-header{flex-direction:column;align-items:flex-start}.form-row,.env-grid{grid-template-columns:1fr}}.environment-lock-control{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}.lock-message{padding:8px 16px;border-radius:6px;font-size:.875rem;font-weight:500;background:#fff3cd;color:#856404;border:1px solid #ffc107;text-align:center}.lock-message.success{background:#d4edda;color:#155724;border-color:#28a745}.lock-message.error{background:#f8d7da;color:#721c24;border-color:#dc3545}.lock-button{width:100%;padding:10px 20px;font-size:.875rem;font-weight:600;border:none;border-radius:6px;cursor:pointer;transition:all .2s ease;white-space:nowrap;box-shadow:0 2px 4px #0000001a}.lock-button.unlocked{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.lock-button.unlocked:hover:not(:disabled){background:linear-gradient(135deg,#5568d3,#64408a);transform:translateY(-1px);box-shadow:0 4px 8px #00000026}.lock-button.locked{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff}.lock-button.locked:hover:not(:disabled){background:linear-gradient(135deg,#e082ea,#e4465b);transform:translateY(-1px);box-shadow:0 4px 8px #00000026}.lock-button:disabled{opacity:.6;cursor:not-allowed;transform:none!important}.lock-button:active:not(:disabled){transform:translateY(0);box-shadow:0 1px 2px #0000001a}@media(max-width:768px){.lock-button{font-size:.8rem}}:root{--primary-color: #1976d2;--secondary-color: #f57c00;--background: #f5f5f5;--text-primary: #333;--text-secondary: #666}*{margin:0;padding:0;box-sizing:border-box}html,body{width:100%;height:100%;overflow-x:hidden}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:var(--background)}.app{min-height:100vh;width:100%;display:flex;flex-direction:column}.app-header{background:linear-gradient(135deg,#1976d2,#1565c0);color:#fff;padding:clamp(20px,5vw,50px) clamp(20px,4vw,40px);box-shadow:0 2px 8px #0000001a;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:20px}.app-header>div:first-child{text-align:left}.user-menu{display:flex;align-items:center;gap:20px}.user-info{font-size:15px;color:#fffffff2}.user-info strong{font-weight:600}.logout-button{padding:10px 24px;background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;white-space:nowrap}.logout-button:hover{background:#ffffff4d;border-color:#ffffff80}.logout-button:active{transform:scale(.98)}.app-tabs{display:flex;gap:4px;background:#0000000d;padding:8px;border-bottom:1px solid rgba(0,0,0,.1)}.tab-button{flex:1;padding:14px 24px;background:transparent;color:#666;border:none;border-radius:8px 8px 0 0;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease}.tab-button:hover{background:#ffffff80;color:#333}.tab-button.active{background:#fff;color:#1976d2;box-shadow:0 -2px 8px #00000014}.app-header h1{font-size:clamp(24px,5vw,42px);margin-bottom:10px;font-weight:700;line-height:1.2}.app-header p{font-size:clamp(14px,3vw,18px);opacity:.9;line-height:1.5}.app-main{flex:1;width:100vw;max-width:100%;padding:clamp(20px,4vw,50px) clamp(16px,3vw,40px);box-sizing:border-box}.no-access{text-align:center;padding:60px 20px;background:#fff;border-radius:12px;max-width:600px;margin:40px auto;box-shadow:0 2px 8px #00000014}.no-access h2{color:#333;margin-bottom:16px;font-size:24px}.no-access p{color:#666;margin-bottom:12px;line-height:1.6;font-size:15px}.admin-panel{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #00000014}.admin-sub-nav{display:flex;gap:8px;padding:16px;background:#f8f9fa;border-bottom:2px solid #e9ecef}.sub-tab-button{flex:1;padding:12px 24px;background:transparent;color:#666;border:2px solid transparent;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:8px}.sub-tab-button:hover{background:#1976d214;color:#1976d2}.sub-tab-button.active{background:#1976d2;color:#fff;border-color:#1976d2}.sub-tab-button.active:hover{background:#1565c0;border-color:#1565c0}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:20px}.loading-spinner{width:50px;height:50px;border:4px solid #f3f3f3;border-top:4px solid #1976d2;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-container p{color:#666;font-size:16px}.environments-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(20px,3vw,24px);width:100%}.environment-section{margin-bottom:0;padding:clamp(16px,3vw,20px);background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014}.environment-title{font-size:clamp(16px,3.5vw,20px);color:var(--primary-color);margin-bottom:clamp(16px,3vw,20px);padding-bottom:12px;border-bottom:2px solid var(--primary-color);font-weight:700}.section-info-row{display:flex;flex-wrap:wrap;gap:12px;padding:12px 16px;background:linear-gradient(135deg,#1976d20d,#1565c014);border-left:4px solid var(--primary-color);border-radius:8px;margin-bottom:16px;align-items:center}.info-item{display:flex;align-items:center;gap:8px;padding:6px 12px;background:#fff;border-radius:6px;font-size:14px;box-shadow:0 1px 3px #00000014}.info-item.warning{border-left:3px solid #ff9800}.info-item.deploying{border-left:3px solid #2196f3}.info-item.ready{border-left:3px solid #4caf50}.info-label{font-weight:600;color:var(--text-secondary)}.info-value{color:var(--text-primary);font-weight:500}.repository-subsection{margin-bottom:clamp(24px,4vw,32px)}.repository-subsection:last-child{margin-bottom:0}.repository-subtitle{font-size:clamp(16px,3.5vw,20px);color:var(--text-secondary);margin-bottom:clamp(12px,2.5vw,16px);font-weight:600;display:flex;align-items:center;gap:8px}.repository-subtitle:before{content:"";width:4px;height:20px;background:var(--secondary-color);border-radius:2px}.deployment-grid{display:grid;grid-template-columns:1fr;gap:clamp(10px,2vw,12px)}.app-footer{background:#fff;padding:clamp(16px,3vw,24px);text-align:center;color:var(--text-secondary);border-top:1px solid #e0e0e0;font-size:clamp(13px,2vw,15px)}@media(min-width:1920px){.environments-grid{grid-template-columns:repeat(4,1fr);gap:24px}.deployment-grid{grid-template-columns:1fr;gap:12px}.app-main{padding:50px 60px}}@media(min-width:1440px)and (max-width:1919px){.environments-grid{grid-template-columns:repeat(4,1fr);gap:24px}.deployment-grid{grid-template-columns:1fr;gap:12px}.app-main{padding:50px 60px}.environment-title{font-size:28px}}@media(min-width:1200px)and (max-width:1439px){.environments-grid{grid-template-columns:repeat(4,1fr);gap:20px}.deployment-grid{grid-template-columns:1fr;gap:12px}}@media(min-width:1025px)and (max-width:1199px){.environments-grid{grid-template-columns:repeat(3,1fr);gap:20px}.deployment-grid{grid-template-columns:1fr;gap:10px}}@media(min-width:900px)and (max-width:1024px){.environments-grid{grid-template-columns:repeat(2,1fr);gap:20px}.deployment-grid{grid-template-columns:1fr;gap:10px}}@media(min-width:768px)and (max-width:899px){.environments-grid{grid-template-columns:repeat(2,1fr);gap:16px}.deployment-grid{grid-template-columns:1fr;gap:10px}}@media(max-width:768px){.app-header{flex-direction:column;align-items:flex-start;gap:20px}.app-header>div:first-child{text-align:center;width:100%}.user-menu{width:100%;justify-content:space-between}.environments-grid{grid-template-columns:1fr;gap:16px}.deployment-grid{grid-template-columns:1fr;gap:10px}.app-main{padding:20px 16px}.app-footer{padding:16px;font-size:13px}}@media(max-width:480px){.app-header{padding:20px 16px}.app-main{padding:16px 12px}.environments-grid{grid-template-columns:1fr;gap:12px}.environment-title{font-size:18px;margin-bottom:12px}.deployment-grid{gap:12px}.app-footer{padding:12px;font-size:12px}}@media(max-width:360px){.app-header h1{font-size:20px}.app-header p{font-size:13px}.environment-title{font-size:16px}}
