:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--bg-surface:#f8f8fa;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#3b82f6;--accent-bg:#3b82f61a;--accent-border:#3b82f680;--danger:#ef4444;--danger-bg:#ef44441a;--success:#22c55e;--success-bg:#22c55e1a;--warning:#f59e0b;--warning-bg:#f59e0b1a;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:15px/1.5 var(--sans);--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial;--text:#9ca3af;--text-h:#f3f4f6;--bg:#111218;--bg-surface:#1a1b23;--border:#2e303a;--code-bg:#1f2028;--accent:#60a5fa;--accent-bg:#60a5fa26;--accent-border:#60a5fa80;--danger:#f87171;--danger-bg:#f8717126;--success:#4ade80;--success-bg:#4ade8026;--warning:#fbbf24;--warning-bg:#fbbf2426}}#root{box-sizing:border-box;width:100%;min-height:100svh}body{margin:0}*{box-sizing:border-box}h1,h2,h3{color:var(--text-h);margin:0;font-weight:600}h1{font-size:24px}h2{font-size:18px}h3{font-size:15px}code{font-family:var(--mono);background:var(--code-bg);color:var(--text-h);border-radius:4px;padding:2px 6px;font-size:13px}button{font-family:var(--sans);cursor:pointer;border:1px solid var(--border);background:var(--bg);color:var(--text-h);border-radius:6px;padding:6px 14px;font-size:14px;transition:background .15s,border-color .15s}button:hover{border-color:var(--accent-border);background:var(--accent-bg)}button.primary{background:var(--accent);color:#fff;border-color:var(--accent)}button.primary:hover{opacity:.9}button.danger{color:var(--danger);border-color:var(--danger)}button.danger:hover{background:var(--danger-bg)}input,select{font-family:var(--sans);border:1px solid var(--border);background:var(--bg);color:var(--text-h);border-radius:6px;outline:none;padding:6px 10px;font-size:14px}input:focus,select:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-bg)}label{color:var(--text);margin-bottom:4px;font-size:13px;font-weight:500;display:block}.envs-table{border-collapse:collapse;width:100%}.envs-table th,.envs-table td{text-align:left;border-bottom:1px solid var(--border);padding:10px 12px}.envs-table th{text-transform:uppercase;letter-spacing:.5px;color:var(--text);font-size:12px;font-weight:600}.envs-table tr{cursor:pointer;transition:background .1s}.envs-table tbody tr:hover{background:var(--accent-bg)}.env-type{text-transform:uppercase;border-radius:10px;padding:2px 8px;font-size:12px;font-weight:600;display:inline-block}.env-type.prod{background:var(--danger-bg);color:var(--danger)}.env-type.preprod{background:var(--warning-bg);color:var(--warning)}.env-type.demo{background:var(--accent-bg);color:var(--accent)}.env-type.qa{background:var(--success-bg);color:var(--success)}.env-type.dev{background:var(--bg-surface);color:var(--text)}.env-detail{flex-direction:column;gap:24px;display:flex}.env-detail .back-link{color:var(--accent);cursor:pointer;text-align:left;background:0 0;border:none;padding:0;font-size:13px}.env-detail .back-link:hover{text-decoration:underline}.env-header{align-items:center;gap:12px;display:flex}.env-header h1{flex:1}.section{background:var(--bg-surface);border:1px solid var(--border);border-radius:8px;padding:16px}.section h2{margin-bottom:12px}.section table{border-collapse:collapse;width:100%}.section table th,.section table td{text-align:left;border-bottom:1px solid var(--border);padding:6px 10px;font-size:14px}.section table th{text-transform:uppercase;letter-spacing:.5px;color:var(--text);font-size:12px;font-weight:600}.section .empty{color:var(--text);font-size:14px;font-style:italic}.section-actions{gap:8px;margin-top:12px;display:flex}.form-grid{grid-template-columns:1fr 1fr;gap:16px;display:grid}.form-grid .full{grid-column:1/-1}.form-field{flex-direction:column;gap:4px;display:flex}.form-actions{gap:8px;margin-top:20px;display:flex}.inline-form{flex-wrap:wrap;align-items:flex-end;gap:8px;display:flex}.inline-form .form-field{flex:1;min-width:120px}.loading{color:var(--text);text-align:center;padding:40px}.error-msg{color:var(--danger);background:var(--danger-bg);border-radius:6px;padding:12px;font-size:14px}.badge-row{flex-wrap:wrap;gap:6px;display:flex}.badge{background:var(--bg-surface);border:1px solid var(--border);color:var(--text);border-radius:10px;padding:2px 8px;font-size:12px}button.draft-remove{color:var(--text);border-color:var(--border);padding:4px 10px;font-size:13px}button.draft-remove:hover{background:var(--bg-surface);border-color:var(--text)}.env-header .spacer{flex:1}.modal-overlay{z-index:100;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--bg);border:1px solid var(--border);min-width:480px;max-width:640px;max-height:80vh;box-shadow:var(--shadow,0 10px 30px #0003);border-radius:12px;padding:24px;overflow-y:auto}.modal h2{margin-bottom:16px}.modal-actions{justify-content:flex-end;gap:8px;margin-top:20px;display:flex}.diff-list{flex-direction:column;gap:6px;display:flex}.diff-item{border-radius:6px;align-items:center;gap:10px;padding:8px 12px;font-size:14px;display:flex}.diff-item.diff-add{background:var(--success-bg)}.diff-item.diff-remove{background:var(--danger-bg)}.diff-item.diff-update{background:var(--accent-bg)}.diff-badge{text-transform:uppercase;text-align:center;min-width:56px;font-size:11px;font-weight:700}.diff-add .diff-badge{color:var(--success)}.diff-remove .diff-badge{color:var(--danger)}.diff-update .diff-badge{color:var(--accent)}.diff-section{color:var(--text-h);min-width:80px;font-weight:600}.diff-detail{color:var(--text);font-family:var(--mono);font-size:13px}.dropdown-wrap{position:relative}.btn-icon{border:1px solid var(--border);cursor:pointer;color:var(--text);background:0 0;border-radius:6px;padding:4px 10px;font-size:18px;line-height:1}.btn-icon:hover{background:var(--bg-surface)}.dropdown-menu{background:var(--bg);border:1px solid var(--border);box-shadow:var(--shadow,0 4px 16px #00000026);z-index:50;border-radius:8px;min-width:180px;padding:4px;position:absolute;top:calc(100% + 4px);right:0}.dropdown-menu button{text-align:left;cursor:pointer;width:100%;color:var(--text);background:0 0;border:none;border-radius:4px;padding:8px 12px;font-size:14px;display:block}.dropdown-menu button:hover{background:var(--accent-bg)}.dropdown-menu button.danger{color:var(--danger)}.dropdown-menu button.danger:hover{background:var(--danger-bg)}.section-icon{vertical-align:-3px;opacity:.7;margin-right:6px}.ext-link{color:var(--accent);font-family:var(--mono);font-size:13px;text-decoration:none}.ext-link:hover{text-decoration:underline}.clusters-table{border-collapse:collapse;width:100%}.clusters-table th,.clusters-table td{text-align:left;border-bottom:1px solid var(--border);padding:10px 12px}.clusters-table th{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.85em;font-weight:600}.clusters-table tbody tr{cursor:pointer}.clusters-table tbody tr:hover{background:var(--bg-hover)}.cluster-status,.node-status{border-radius:4px;padding:2px 8px;font-size:.85em;font-weight:500;display:inline-block}.status-pending{color:var(--text-muted);background:#4444}.status-provisioning{color:#ffae00;background:#ffae0033}.status-ready{color:#00d974;background:#00d97433}.status-failed{color:#ff5e5e;background:#ff5e5e33}.status-draining{color:#ffae00;background:#ffae0033}.status-deleting{color:#ff5e5e;background:#ff5e5e33}.status-deleted{color:var(--text-muted);background:#4444}.role-badge{border-radius:4px;padding:2px 8px;font-size:.85em;font-weight:500;display:inline-block}.role-owner{color:#9b87ff;background:#6f5fff33}.role-operator,.role-admin{color:#5cd0ff;background:#00b4ff33}.role-reader,.role-member{color:var(--text-muted);background:#4444}.cloud-badge{border-radius:4px;padding:2px 8px;font-size:.85em;font-weight:500;display:inline-block}.cloud-hetzner{color:#ff6b85;background:#d50c2d33}.cloud-oci{color:#ff8fa3;background:#f8000033}.cloud-local{color:var(--text-muted);background:#4444}.cluster-overview{background:var(--bg-soft);border-radius:8px;align-items:flex-start;gap:32px;margin-bottom:24px;padding:16px;display:flex}.cluster-overview dl{flex:1;grid-template-columns:max-content 1fr;gap:8px 16px;min-width:0;margin:0;display:grid}.cluster-overview dt{color:var(--text-muted);font-size:.9em}.cluster-overview dd{word-break:break-all;margin:0;font-size:.9em}.cluster-overview dd code.trunc{text-overflow:ellipsis;white-space:nowrap;vertical-align:middle;max-width:60ch;display:inline-block;overflow:hidden}.cluster-actions{flex-direction:column;gap:8px;min-width:220px;display:flex}.cluster-actions button{width:100%}.cluster-section{margin-top:32px}.cluster-section h2{color:var(--text);margin-bottom:12px;font-size:1.1em}.cluster-section-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.cluster-section-header h2{margin:0}.cluster-nodes-table,.cluster-members-table{border-collapse:collapse;width:100%;margin-bottom:16px}.cluster-nodes-table th,.cluster-nodes-table td,.cluster-members-table th,.cluster-members-table td{text-align:left;border-bottom:1px solid var(--border);padding:8px 12px;font-size:.9em}.cluster-nodes-table th,.cluster-members-table th{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.85em;font-weight:600}.status-msg{color:var(--text-muted);margin-left:4px;font-style:italic}.cluster-form{flex-direction:column;gap:8px;max-width:720px;display:flex}.cluster-form.inline{background:var(--bg-soft);border-radius:8px;margin-top:12px;padding:16px}.cluster-form.inline h3{margin:0 0 12px;font-size:1em}.cluster-form label,.modal .cluster-form label{flex-direction:column;gap:4px;margin:0;font-size:.9em;display:flex}.cluster-form label>span{color:var(--text);font-weight:500}.cluster-form label.checkbox{flex-direction:row;align-items:center;gap:8px}.cluster-form input:not([type=checkbox]),.cluster-form select{box-sizing:border-box;border:1px solid var(--border);background:var(--bg);width:100%;color:var(--text);border-radius:4px;padding:8px 10px;font-family:inherit;font-size:.95em;display:block}.cluster-form small{color:var(--text-muted);font-size:.85em;line-height:1.4}.info-tip{color:var(--text-muted);cursor:help;-webkit-user-select:none;user-select:none;opacity:.7;margin-left:2px;font-size:.9em;display:inline-block}.info-tip:hover{opacity:1;color:var(--text)}.advanced-section{background:var(--bg-soft);border-radius:6px;padding:0}.advanced-section>summary{cursor:pointer;color:var(--text-muted);-webkit-user-select:none;user-select:none;align-items:center;gap:6px;padding:10px 14px;font-size:.9em;list-style:none;display:flex}.advanced-section>summary::-webkit-details-marker{display:none}.advanced-section>summary:before{content:"▸";font-size:.8em;transition:transform .15s;display:inline-block}.advanced-section[open]>summary:before{transform:rotate(90deg)}.advanced-section>summary:hover{color:var(--text)}.advanced-fields{flex-direction:column;gap:16px;padding:4px 14px 14px;display:flex}.cluster-form .form-row{flex-wrap:wrap;align-items:flex-end;gap:12px;display:flex}.cluster-form .form-row>label{flex:1;min-width:200px}.cluster-form .form-actions{justify-content:flex-end;gap:8px;display:flex}button.small{padding:4px 10px;font-size:.85em}.hint{color:var(--text-muted);font-size:.9em;font-style:italic}.bulk-preview{background:var(--bg-soft);border-radius:6px;padding:12px 14px}.bulk-preview h3{color:var(--text);margin:0 0 8px;font-size:.95em}.bulk-preview ul{margin:0 0 8px;padding-left:18px;list-style:outside}.bulk-preview li{color:var(--text);margin:2px 0;font-size:.9em}.bulk-preview small{color:var(--text-muted);font-size:.85em}.cluster-live-log{background:var(--bg-soft);border-left:3px solid #5cd0ff;border-radius:4px;margin:16px 0;padding:12px 16px}.cluster-live-log header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.cluster-live-log h3{color:var(--text);margin:0;font-size:.95em}.cluster-live-log pre{font-family:var(--font-mono,monospace);color:var(--text);white-space:pre-wrap;word-break:break-all;max-height:280px;margin:0;font-size:.85em;line-height:1.5;overflow-y:auto}.mode-toggle{background:var(--bg-soft);border-radius:6px;gap:4px;margin-bottom:4px;padding:4px;display:flex}.mode-tab{cursor:pointer;-webkit-user-select:none;user-select:none;color:var(--text-muted);border-radius:4px;flex:1;justify-content:center;align-items:center;padding:8px 12px;font-size:.9em;transition:background .1s,color .1s;display:flex}.mode-tab input[type=radio]{display:none}.mode-tab.active{background:var(--bg);color:var(--text);font-weight:500}.mode-tab:hover:not(.active){color:var(--text)}.cluster-form input.invalid{border-color:#ff5e5e}.modal.modal-wide{max-width:720px}.component-row{border-top:1px solid var(--border);padding:12px 0 8px}.component-row:first-child{border-top:none;padding-top:0}.component-row>small{color:var(--text-muted);margin:4px 0 0 26px;display:block}.component-config{background:var(--bg-soft);border-radius:6px;flex-direction:column;gap:8px;margin:10px 0 0 26px;padding:10px 12px;display:flex}.kv-pairs{border:1px solid var(--border);border-radius:6px;margin:0;padding:10px 12px}.kv-pairs legend{color:var(--text);align-items:center;gap:6px;padding:0 6px;font-size:.9em;font-weight:500;display:inline-flex}.reveal-toggle{background:var(--bg-soft);border:1px solid var(--border);color:var(--text-muted);cursor:pointer;border-radius:3px;margin-left:12px;padding:2px 8px;font-size:.8em}.reveal-toggle:hover{color:var(--text)}.account-section{background:var(--bg-soft);border-radius:8px;margin:16px 0;padding:12px 16px}.account-section header{align-items:center;gap:12px;margin-bottom:8px;display:flex}.account-section header h3{margin:0;font-size:1.05em}.account-section .hint{margin-bottom:12px}.account-section .cluster-form{background:0 0;padding:0}.ssh-key-list{flex-direction:column;gap:6px;margin:0 0 12px;padding:0;list-style:none;display:flex}.ssh-key-row{background:var(--bg);border:1px solid var(--border);border-radius:4px;grid-template-columns:minmax(0,1.2fr) minmax(0,2fr) auto;align-items:center;gap:12px;padding:8px 10px;display:grid}.ssh-key-meta{flex-direction:column;gap:2px;min-width:0;display:flex}.ssh-key-fp{color:var(--text-muted);text-overflow:ellipsis;font-size:.8em;overflow:hidden}.ssh-key-preview{color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;font-size:.8em;overflow:hidden}.kv-row{align-items:center;gap:6px;margin-bottom:6px;display:flex}.kv-row>input{flex:1;margin:0!important}.kv-row>button{background:var(--bg-soft);border:1px solid var(--border);color:var(--text-muted);cursor:pointer;border-radius:3px;flex-shrink:0;padding:4px 10px;font-size:1em}.kv-row>button:hover{color:#ff5e5e;border-color:#ff5e5e}.form-errors{color:var(--text);background:#ff5e5e11;border:1px solid #ff5e5e44;border-radius:6px;margin:8px 0;padding:8px 12px 8px 28px;font-size:.9em;list-style:outside}.form-errors li{margin:2px 0}.warning-box{color:var(--text);background:#ffae0011;border:1px solid #ffae0044;border-radius:6px;padding:10px 14px;font-size:.9em}.warning-box strong{color:#ffae00;margin-bottom:6px;display:block}.warning-box p{margin:0 0 8px}.ssh-hint{background:var(--bg);border:1px solid var(--border);font-family:var(--font-mono,monospace);white-space:pre-wrap;word-break:break-all;color:var(--text);border-radius:4px;margin:0;padding:8px 10px;font-size:.8em}.toast-stack{z-index:1000;pointer-events:none;flex-direction:column;gap:8px;max-width:480px;display:flex;position:fixed;bottom:16px;right:16px}.toast{background:var(--bg-soft);border-left:4px solid var(--text-muted);pointer-events:auto;border-radius:8px;align-items:flex-start;gap:12px;padding:12px 16px;animation:.15s ease-out toast-in;display:flex;box-shadow:0 8px 24px #0000004d}.toast-closing{animation:.2s ease-in forwards toast-out}@keyframes toast-in{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes toast-out{to{opacity:0;transform:translate(20px)}}.toast-error{border-left-color:#ff5e5e}.toast-warning{border-left-color:#ffae00}.toast-info{border-left-color:#5cd0ff}.toast-success{border-left-color:#00d974}.toast-body{flex:1;min-width:0}.toast-title{color:var(--text);margin-bottom:4px;font-weight:600}.toast-message{color:var(--text);word-break:break-word;font-size:.9em;line-height:1.4}.toast-hint{font-family:var(--font-mono,monospace);color:var(--text-muted);white-space:pre-wrap;word-break:break-all;background:#00000040;border-radius:4px;max-height:200px;margin:8px 0 0;padding:8px 10px;font-size:.8em;overflow-y:auto}.toast-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:0 4px;font-size:1.4em;line-height:1}.toast-close:hover{color:var(--text)}.csb{width:var(--csb-width,260px);border-right:1px solid var(--border);background:var(--bg);z-index:10;flex-shrink:0;transition:width .2s,padding .2s;position:relative;overflow-y:auto}.csb.csb--full{flex:1;width:auto}.csb__inner{padding:16px}.csb__rail{display:none}.csb__placeholder{flex-shrink:0;transition:width .2s}.csb__actions{opacity:0;z-index:2;gap:4px;transition:opacity .15s;display:flex;position:absolute;top:8px;right:8px}.csb:hover .csb__actions,.csb--pinned .csb__actions{opacity:1}.csb__action{cursor:pointer;background:0 0;border:1px solid #0000;border-radius:6px;justify-content:center;align-items:center;width:28px;height:28px;padding:0;font-size:14px;transition:background .15s,border-color .15s;display:flex}.csb__action:hover{background:var(--accent-bg);border-color:var(--border)}.csb.csb--collapsed{width:var(--csb-rail,25px);padding:0;position:absolute;top:0;bottom:0;left:0;overflow:hidden}.csb.csb--collapsed .csb__inner{opacity:0;pointer-events:none;transition:opacity .15s}.csb.csb--collapsed .csb__rail{width:var(--csb-rail,25px);cursor:pointer;height:100%;color:var(--text);background:0 0;border:none;justify-content:center;align-items:center;padding:0;font-size:14px;transition:color .15s,background .15s;display:flex}.csb.csb--collapsed .csb__rail:hover{color:var(--accent);background:var(--accent-bg)}.csb.csb--collapsed:not(.csb--pinned):hover{width:var(--csb-width,260px);background:var(--bg);padding:0;overflow-y:auto;box-shadow:4px 0 16px #00000026}.csb.csb--collapsed:not(.csb--pinned):hover .csb__inner{opacity:1;pointer-events:auto}.csb.csb--collapsed:not(.csb--pinned):hover .csb__rail{display:none}.csb.csb--pinned{width:var(--csb-width,260px);padding:0;overflow-y:auto}.csb.csb--pinned .csb__inner{opacity:1;pointer-events:auto}.csb.csb--pinned .csb__rail{display:none}.app-shell{flex-direction:column;height:100svh;display:flex}.app-body{flex:1;min-height:0;display:flex;position:relative;overflow:hidden}.app-sidebar-list{flex-direction:column;gap:2px;margin:0;padding:0;list-style:none;display:flex}.app-sidebar-item{color:var(--text);border-radius:6px;padding:8px 12px;font-size:14px;font-weight:500;text-decoration:none;transition:background .15s,color .15s;display:block}.app-sidebar-item:hover{background:var(--accent-bg);color:var(--text-h)}.app-sidebar-item.active{background:var(--accent-bg);color:var(--accent)}.app-nav{border-bottom:1px solid var(--border);background:var(--bg-surface);align-items:center;gap:4px;padding:8px 16px;display:flex}.app-nav button{color:var(--text);background:0 0;border:none;border-radius:6px;padding:6px 14px;font-weight:500}.app-nav button:hover{background:var(--accent-bg);color:var(--text-h)}.app-nav button.active{background:var(--accent-bg);color:var(--accent)}.app-nav .spacer{flex:1}.app-nav .user-menu{color:var(--text);font-size:13px}.app-nav .user-menu button{color:var(--text);padding:4px 10px;font-size:13px}.app-nav .user-menu .role-badge{text-transform:uppercase;border-radius:10px;margin-right:6px;padding:2px 7px;font-size:11px;font-weight:600}.role-badge.role-admin{background:var(--danger-bg);color:var(--danger)}.role-badge.role-consumer{background:var(--accent-bg);color:var(--accent)}.app-content{flex:1;min-width:0;padding:24px;overflow-y:auto}.page-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}
