*,*:before,*:after{box-sizing:border-box}:root{--base: #11111b;--surface: #1e1e2e;--mantle: #181825;--overlay0: #313244;--overlay1: #45475a;--overlay2: #585b70;--subtext0: #6c7086;--subtext1: #a6adc8;--text: #cdd6f4;--blue: #89b4fa;--red: #f38ba8;--green: #a6e3a1;--peach: #fab387;--sky: #74c7ec;--mauve: #cba6f7;--red-surface: #2d1b22;--green-surface:#1a2b1a;--peach-surface:#2b2418;--red-a: #f38ba822;--green-a: #a6e3a122;--blue-a: #89b4fa22;--blue-a-sm: #89b4fa11;--blue-a-lg: #89b4fa55}[data-theme=light]{color-scheme:light;--base: #eff1f5;--surface: #e6e9ef;--mantle: #dce0e8;--overlay0: #bcc0cc;--overlay1: #acb0be;--overlay2: #9ca0b0;--subtext0: #6c6f85;--subtext1: #5c5f77;--text: #4c4f69;--blue: #1e66f5;--red: #d20f39;--green: #40a02b;--peach: #fe640b;--sky: #209fb5;--mauve: #8839ef;--red-surface: #fce5e8;--green-surface:#e5f5e5;--peach-surface:#fff3e8;--red-a: #d20f3922;--green-a: #40a02b22;--blue-a: #1e66f522;--blue-a-sm: #1e66f511;--blue-a-lg: #1e66f555}:root{font-family:system-ui,-apple-system,sans-serif;font-size:16px;line-height:1.5;font-weight:400;color-scheme:dark;color:var(--text);background-color:var(--base);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}body{margin:0;min-height:100vh}#root{min-height:100vh}button{font-family:inherit}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--overlay1);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--overlay2)}h1,h2,h3{line-height:1.2}.start-form{background:var(--surface);border:1px solid var(--overlay0);border-radius:12px;padding:1.5rem;display:flex;flex-direction:column;gap:1rem}.start-form h2{margin:0;font-size:1.1rem;color:var(--text)}.form-group{display:flex;flex-direction:column;gap:.4rem}.form-group label{font-size:.85rem;color:var(--subtext1)}.form-group select{background:var(--mantle);border:1px solid var(--overlay1);border-radius:8px;color:var(--text);padding:.5rem .75rem;font-size:.95rem;cursor:pointer}.form-group select:focus{outline:none;border-color:var(--blue)}.form-group input[type=range]{accent-color:var(--blue);width:100%;cursor:pointer}.range-labels{display:flex;justify-content:space-between;font-size:.75rem;color:var(--subtext0)}.custom-multi-hint{font-size:.78rem;color:var(--subtext0);background:var(--mantle);border:1px solid var(--overlay0);border-radius:6px;padding:.4rem .65rem;margin:0}.form-error{color:var(--red);font-size:.85rem;margin:0;background:var(--surface);border:1px solid var(--red);border-radius:6px;padding:.5rem .75rem}.btn-start{background:var(--blue);color:var(--surface);border:none;border-radius:8px;padding:.6rem 1.2rem;font-size:.95rem;font-weight:600;cursor:pointer;transition:background .2s}.btn-start:hover:not(:disabled){background:var(--sky)}.btn-start:disabled{opacity:.5;cursor:not-allowed}.mode-tabs{display:flex;gap:0;background:var(--mantle);border:1px solid var(--overlay1);border-radius:8px;padding:3px}.mode-tab{flex:1;background:transparent;border:none;border-radius:6px;color:var(--subtext0);padding:.35rem 0;font-size:.85rem;font-weight:600;cursor:pointer;transition:background .15s,color .15s}.mode-tab.active{background:var(--overlay0);color:var(--text)}.mode-tab:hover:not(.active){color:var(--subtext1)}.stack-name-input{background:var(--mantle);border:1px solid var(--overlay1);border-radius:8px;color:var(--text);padding:.5rem .75rem;font-size:.9rem;width:100%;box-sizing:border-box}.stack-name-input:focus{outline:none;border-color:var(--blue)}.stack-name-input::placeholder{color:var(--overlay1)}.label-hint{color:var(--blue);font-size:.78rem}.service-grid{display:flex;flex-wrap:wrap;gap:.4rem;max-height:220px;overflow-y:auto;padding:.25rem 0}.service-chip{display:flex;align-items:center;gap:.3rem;background:var(--mantle);border:1px solid var(--overlay0);border-radius:6px;color:var(--subtext1);padding:.3rem .6rem;font-size:.78rem;cursor:pointer;transition:border-color .15s,background .15s,color .15s;white-space:nowrap}.service-chip:hover{border-color:var(--blue-a-lg);color:var(--text)}.service-chip.selected{border-color:var(--blue);background:var(--blue)18;color:var(--blue)}.chip-label{font-weight:500}.btn-config-toggle{display:flex;justify-content:space-between;align-items:center;width:100%;background:var(--mantle);border:1px solid var(--overlay0);border-radius:8px;color:var(--subtext1);padding:.45rem .75rem;font-size:.85rem;cursor:pointer;transition:border-color .15s,color .15s}.btn-config-toggle:hover,.btn-config-toggle.open{border-color:var(--blue-a-lg);color:var(--text)}.toggle-arrow{font-size:.7rem;color:var(--subtext0)}.config-panel{background:var(--mantle);border:1px solid var(--overlay0);border-radius:8px;padding:1rem 1.1rem;display:flex;flex-direction:column;gap:.7rem}.config-section-label{font-size:.75rem;color:var(--subtext0);text-transform:uppercase;letter-spacing:.05em;margin-top:.3rem}.config-row{display:flex;align-items:center;gap:.75rem}.config-label{font-size:.82rem;color:var(--subtext1);width:6.5rem;flex-shrink:0}.config-input{flex:1;background:var(--surface);border:1px solid var(--overlay1);border-radius:6px;color:var(--text);padding:.4rem .7rem;font-size:.88rem;min-width:0}.config-input:focus{outline:none;border-color:var(--blue)}.config-input::placeholder{color:var(--overlay1)}.config-input-sm{max-width:7.5rem;flex:0 0 7.5rem}.config-mem-slider{flex:1;display:flex;flex-direction:column;gap:.25rem}.config-mem-slider input[type=range]{width:100%;accent-color:var(--blue);cursor:pointer}.config-mem-labels{display:flex;justify-content:space-between;font-size:.7rem;color:var(--subtext0)}.config-mem-value{font-size:.82rem;font-weight:600;color:var(--blue);text-align:right;min-width:4.5rem;flex-shrink:0}.config-env-row{display:flex;align-items:center;gap:.4rem}.config-env-key{flex:0 0 40%;font-family:monospace;font-size:.8rem}.config-env-val{flex:1;font-family:monospace;font-size:.8rem}.config-env-sep{color:var(--subtext0);font-size:.9rem;flex-shrink:0}.btn-add-env{background:transparent;border:1px dashed var(--overlay1);border-radius:6px;color:var(--subtext0);padding:.3rem .6rem;font-size:.8rem;cursor:pointer;transition:border-color .15s,color .15s;align-self:flex-start;margin-top:.1rem}.stack-step-header{display:flex;flex-direction:column;gap:.1rem}.stack-step-label{font-size:.7rem;color:var(--subtext0);text-transform:uppercase;letter-spacing:.05em}.stack-step-title{font-size:.9rem;font-weight:600;color:var(--text)}.chip-multi{background:var(--overlay0);color:var(--subtext1);font-size:.65rem;border-radius:99px;padding:.05rem .35rem;font-weight:700;line-height:1.4}.stack-containers-list{display:flex;flex-direction:column;gap:.75rem;max-height:340px;overflow-y:auto}.stack-container-block{background:var(--mantle);border:1px solid var(--overlay0);border-radius:8px;padding:.75rem;display:flex;flex-direction:column;gap:.45rem}.scb-header{display:flex;align-items:baseline;gap:.5rem;margin-bottom:.1rem}.scb-image{font-size:.8rem;font-weight:600;color:var(--blue);font-family:monospace}.scb-from{font-size:.7rem;color:var(--subtext0)}.scb-row{display:flex;align-items:center;gap:.5rem}.scb-label{font-size:.75rem;color:var(--subtext0);width:5.5rem;flex-shrink:0}.scb-input{flex:1;background:var(--surface);border:1px solid var(--overlay0);border-radius:6px;color:var(--text);font-size:.82rem;padding:.3rem .5rem;outline:none;transition:border-color .15s}.scb-input:focus{border-color:var(--blue)}.scb-input-sm{max-width:140px}.scb-env-label{font-size:.72rem;color:var(--subtext0);text-transform:uppercase;letter-spacing:.04em;margin-top:.1rem}.stack-step2-actions{display:flex;gap:.5rem}.btn-back{background:var(--mantle);border:1px solid var(--overlay1);border-radius:8px;color:var(--subtext1);font-size:.875rem;padding:.6rem .9rem;cursor:pointer;transition:border-color .15s,color .15s;flex-shrink:0}.btn-back:hover{border-color:var(--overlay2);color:var(--text)}.stack-palette-label{font-size:.72rem;color:var(--subtext0);text-transform:uppercase;letter-spacing:.05em}.stack-palette{display:flex;flex-wrap:wrap;gap:.35rem}.palette-chip{display:flex;align-items:center;gap:.3rem;background:var(--mantle);border:1px solid var(--overlay0);border-radius:6px;color:var(--subtext1);padding:.28rem .55rem;font-size:.78rem;cursor:grab;-webkit-user-select:none;user-select:none;transition:border-color .15s,background .15s,color .15s;white-space:nowrap}.palette-chip:hover{border-color:var(--blue);color:var(--text);background:var(--surface)}.palette-chip:active{cursor:grabbing}.palette-label{font-weight:500}.palette-multi{background:var(--overlay0);color:var(--subtext1);font-size:.62rem;border-radius:99px;padding:.05rem .3rem;font-weight:700;line-height:1.4}.stack-drop-zone{min-height:72px;border:1.5px dashed var(--overlay1);border-radius:10px;padding:.5rem;display:flex;flex-direction:column;gap:.45rem;transition:border-color .15s,background .15s}.stack-drop-zone.dz-over{border-color:var(--blue);background:color-mix(in srgb,var(--blue) 6%,transparent)}.dz-empty{display:flex;align-items:center;justify-content:center;min-height:52px;pointer-events:none}.dz-hint{font-size:.8rem;color:var(--overlay2)}.si-block{background:var(--mantle);border:1px solid var(--overlay0);border-radius:8px;overflow:hidden}.si-header{display:flex;align-items:center;gap:.45rem;padding:.45rem .6rem}.si-icon{font-size:1rem;flex-shrink:0}.si-name{font-size:.82rem;font-weight:600;color:var(--text);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.si-image{font-size:.72rem;color:var(--subtext0);font-family:monospace;flex-shrink:0;max-width:7rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.si-btn-expand,.si-btn-remove{background:transparent;border:none;cursor:pointer;border-radius:4px;padding:.15rem .35rem;font-size:.75rem;flex-shrink:0;transition:color .15s}.si-btn-expand{color:var(--subtext0)}.si-btn-expand:hover{color:var(--blue)}.si-btn-remove{color:var(--subtext0)}.si-btn-remove:hover{color:var(--red)}.si-config{border-top:1px solid var(--overlay0);padding:.6rem .75rem;display:flex;flex-direction:column;gap:.4rem}.si-row{display:flex;align-items:center;gap:.5rem}.si-label{font-size:.75rem;color:var(--subtext0);width:5.5rem;flex-shrink:0}.si-input{flex:1;background:var(--surface);border:1px solid var(--overlay0);border-radius:6px;color:var(--text);font-size:.82rem;padding:.3rem .5rem;outline:none;transition:border-color .15s;min-width:0}.si-input:focus{border-color:var(--blue)}.si-input-sm{max-width:130px;flex:0 0 130px}.si-env-title{font-size:.7rem;color:var(--subtext0);text-transform:uppercase;letter-spacing:.04em;margin-top:.15rem}.modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-box{background:var(--surface);border:1px solid var(--overlay1);border-radius:14px;width:100%;max-width:540px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--overlay0)}.modal-title{font-size:1rem;font-weight:600;color:var(--text)}.modal-close{background:transparent;border:none;color:var(--subtext0);font-size:1rem;cursor:pointer;padding:.2rem .4rem;border-radius:4px}.modal-close:hover{color:var(--red)}.modal-body{padding:1rem 1.25rem;overflow-y:auto;display:flex;flex-direction:column;gap:.7rem;flex:1}.modal-hint{padding:1.5rem;color:var(--subtext0);text-align:center}.modal-row{display:flex;align-items:center;gap:.75rem}.modal-label{font-size:.82rem;color:var(--subtext1);width:7rem;flex-shrink:0}.modal-input{flex:1;background:var(--mantle);border:1px solid var(--overlay1);border-radius:6px;color:var(--text);padding:.4rem .7rem;font-size:.88rem;min-width:0}.modal-input:focus{outline:none;border-color:var(--blue)}.modal-input::placeholder{color:var(--overlay1)}.modal-input-sm{max-width:7rem;flex:0 0 7rem}.modal-mem-slider{flex:1;display:flex;flex-direction:column;gap:.2rem}.modal-mem-slider input[type=range]{width:100%;accent-color:var(--blue);cursor:pointer}.modal-mem-labels{display:flex;justify-content:space-between;font-size:.7rem;color:var(--subtext0)}.modal-mem-value{font-size:.82rem;font-weight:600;color:var(--blue);min-width:4.5rem;text-align:right;flex-shrink:0}.modal-section-label{font-size:.75rem;color:var(--subtext0);text-transform:uppercase;letter-spacing:.05em;margin-top:.3rem}.modal-env-row{display:flex;align-items:center;gap:.4rem}.modal-env-key{flex:0 0 38%;font-family:monospace;font-size:.82rem}.modal-env-val{flex:1;font-family:monospace;font-size:.82rem}.modal-env-sep{color:var(--subtext0);font-size:.9rem;flex-shrink:0}.btn-env-remove{background:transparent;border:none;color:var(--subtext0);cursor:pointer;font-size:.75rem;padding:.2rem .3rem;border-radius:4px;flex-shrink:0}.btn-env-remove:hover{color:var(--red)}.btn-add-env{background:transparent;border:1px dashed var(--overlay1);border-radius:6px;color:var(--subtext0);padding:.3rem .6rem;font-size:.8rem;cursor:pointer;transition:border-color .15s,color .15s;align-self:flex-start}.btn-add-env:hover{border-color:var(--blue-a-lg);color:var(--blue)}.modal-error{color:var(--red);font-size:.85rem;background:var(--red)11;border:1px solid var(--red);border-radius:6px;padding:.5rem .75rem;margin:0}.modal-footer{display:flex;gap:.75rem;justify-content:flex-end;padding:.875rem 1.25rem;border-top:1px solid var(--overlay0)}.modal-btn-cancel{background:transparent;border:1px solid var(--overlay1);border-radius:8px;color:var(--subtext1);padding:.5rem 1rem;font-size:.88rem;cursor:pointer}.modal-btn-cancel:hover{border-color:var(--subtext0)}.modal-btn-save{background:var(--blue);border:none;border-radius:8px;color:var(--surface);padding:.5rem 1.1rem;font-size:.88rem;font-weight:600;cursor:pointer;transition:background .2s}.modal-btn-save:hover:not(:disabled){background:var(--sky)}.modal-btn-save:disabled{opacity:.5;cursor:not-allowed}.logs-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:200;padding:1.5rem}.logs-modal{background:var(--base);border:1px solid var(--overlay0);border-radius:12px;width:100%;max-width:900px;height:75vh;display:flex;flex-direction:column;overflow:hidden;position:relative}.logs-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:var(--surface);border-bottom:1px solid var(--overlay0);flex-shrink:0;gap:1rem}.logs-title{display:flex;align-items:center;gap:.5rem;min-width:0}.logs-icon{font-size:1rem;color:var(--subtext0);flex-shrink:0}.logs-name{font-size:.9rem;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.logs-live-badge{font-size:.72rem;font-weight:700;color:var(--green);letter-spacing:.05em;flex-shrink:0;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.logs-controls{display:flex;align-items:center;gap:.35rem;flex-shrink:0}.logs-tail-label{font-size:.78rem;color:var(--subtext0);margin-right:.1rem}.logs-tail-btn{background:var(--mantle);border:1px solid var(--overlay0);border-radius:5px;color:var(--subtext1);font-size:.75rem;padding:.2rem .5rem;cursor:pointer;transition:all .15s}.logs-tail-btn:hover{border-color:var(--overlay1);color:var(--text)}.logs-tail-btn.active{background:var(--overlay0);border-color:var(--blue);color:var(--blue)}.logs-actions{display:flex;gap:.25rem;margin-left:.25rem}.logs-action-btn{background:transparent;border:1px solid var(--overlay1);border-radius:6px;color:var(--subtext0);font-size:.85rem;width:1.8rem;height:1.8rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.logs-action-btn:hover:not(:disabled){border-color:var(--blue);color:var(--blue);background:var(--blue-a-sm)}.logs-action-btn:disabled{opacity:.3;cursor:default}.logs-close-btn{background:transparent;border:1px solid var(--overlay1);border-radius:6px;color:var(--subtext0);font-size:.85rem;width:1.8rem;height:1.8rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;margin-left:.25rem}.logs-close-btn:hover{border-color:var(--red);color:var(--red)}.logs-body{flex:1;overflow-y:auto;padding:.75rem 1rem;font-family:JetBrains Mono,Fira Code,Cascadia Code,monospace;font-size:.78rem;line-height:1.6;color:var(--text)}.logs-body::-webkit-scrollbar{width:6px}.logs-body::-webkit-scrollbar-track{background:transparent}.logs-body::-webkit-scrollbar-thumb{background:var(--overlay1);border-radius:3px}.log-line{white-space:pre-wrap;word-break:break-all;padding:.05rem 0;border-bottom:1px solid transparent}.log-line:hover{background:var(--surface);border-color:var(--overlay0);border-radius:3px}.logs-hint{color:var(--subtext0);font-size:.85rem;font-family:sans-serif}.logs-scroll-btn{position:absolute;bottom:1rem;right:1rem;background:var(--overlay0);border:1px solid var(--overlay1);border-radius:20px;color:var(--text);font-size:.78rem;padding:.35rem .85rem;cursor:pointer;transition:all .15s}.logs-scroll-btn:hover{background:var(--overlay1)}.toast-container{position:fixed;bottom:1.5rem;right:1.5rem;display:flex;flex-direction:column;gap:.5rem;z-index:1000;pointer-events:none}.toast{display:flex;align-items:center;gap:.75rem;padding:.65rem .9rem;border-radius:8px;border:1px solid;font-size:.85rem;max-width:360px;pointer-events:all;animation:toast-in .2s ease;box-shadow:0 4px 16px #0006}@keyframes toast-in{0%{opacity:0;transform:translate(1rem)}to{opacity:1;transform:translate(0)}}.toast-error{background:var(--red-surface);border-color:var(--red);color:var(--red)}.toast-success{background:var(--green-surface);border-color:var(--green);color:var(--green)}.toast-warning{background:var(--peach-surface);border-color:var(--peach);color:var(--peach)}.toast-msg{flex:1;color:var(--text);line-height:1.4}.toast-close{background:transparent;border:none;cursor:pointer;color:var(--subtext0);font-size:.75rem;padding:0;flex-shrink:0;transition:color .15s}.toast-close:hover{color:var(--text)}.container-card{background:var(--surface);border:1px solid var(--overlay0);border-radius:12px;padding:1.25rem;display:flex;flex-direction:column;gap:.875rem;transition:border-color .2s}.container-card:hover{border-color:var(--overlay1)}.card-header{display:flex;align-items:center;gap:.75rem}.card-icon{font-size:1.5rem;line-height:1}.card-title{flex:1;display:flex;flex-direction:column;gap:.2rem}.card-name{font-size:.9rem;font-weight:600;color:var(--text);word-break:break-all}.card-status{font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:.05em}.status-paused{color:var(--peach)}.status-exited{color:var(--red)}.card-stopped{opacity:.7;border-color:var(--overlay1)}.card-actions{display:flex;align-items:center;gap:.4rem}.card-actions .btn-stop,.card-actions .btn-start,.card-actions .btn-restart,.card-actions .btn-remove,.card-actions .btn-logs{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;border-radius:6px;font-size:.9rem;cursor:pointer;background:transparent;transition:background .2s,color .2s,border-color .2s;flex-shrink:0}.card-actions .btn-stop:disabled,.card-actions .btn-start:disabled,.card-actions .btn-restart:disabled{opacity:.4;cursor:default}.card-actions .btn-logs{border:1px solid var(--overlay1);color:var(--subtext0);font-size:1rem}.card-actions .btn-logs:hover{background:var(--blue-a);border-color:var(--blue);color:var(--blue)}.card-actions .btn-stop{border:1px solid var(--red);color:var(--red)}.card-actions .btn-stop:hover{background:var(--red-a)}.card-actions .btn-start{border:1px solid var(--green);color:var(--green)}.card-actions .btn-start:hover{background:var(--green-a)}.card-actions .btn-restart{border:1px solid var(--blue);color:var(--blue)}.card-actions .btn-restart:hover{background:var(--blue-a)}.card-actions .btn-remove{border:1px solid var(--overlay1);color:var(--subtext0)}.card-actions .btn-remove:hover{background:var(--red-a);border-color:var(--red);color:var(--red)}.card-actions .btn-confirm-yes{border:1px solid var(--green);color:var(--green)}.card-actions .btn-confirm-yes:hover{background:var(--green-a)}.card-actions .btn-confirm-no{border:1px solid var(--overlay1);color:var(--subtext0)}.card-actions .btn-confirm-no:hover{background:var(--red-a);border-color:var(--red);color:var(--red)}.card-meta{display:flex;gap:1.5rem;font-size:.82rem;color:var(--subtext1)}.card-meta strong{color:var(--text)}.card-countdown{margin-left:auto;font-size:.8rem;color:var(--subtext0)}.card-stats{display:flex;flex-direction:column;gap:.5rem}.stat{display:flex;align-items:center;gap:.6rem}.stat-label{font-size:.75rem;color:var(--subtext0);width:2.5rem;flex-shrink:0}.stat-bar{flex:1;height:6px;background:var(--overlay0);border-radius:99px;overflow:hidden}.stat-fill{height:100%;border-radius:99px;transition:width .4s ease}.stat-value{font-size:.78rem;font-weight:600;width:4.5rem;text-align:right;flex-shrink:0}.container-row{background:var(--surface);border:1px solid var(--overlay0);border-radius:8px;padding:.55rem .9rem;display:flex;align-items:center;gap:.75rem;cursor:pointer;transition:border-color .15s}.container-row:hover{border-color:var(--overlay1)}.row-icon-sm{font-size:1.1rem;line-height:1;flex-shrink:0}.row-info-sm{display:flex;flex-direction:column;gap:.1rem;min-width:0;flex:0 0 180px}.row-name-sm{font-size:.82rem;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.row-status-sm{font-size:.7rem;font-weight:500;text-transform:uppercase;letter-spacing:.04em}.row-port-sm{font-size:.8rem;color:var(--subtext0);font-family:monospace;flex-shrink:0}.row-countdown-sm{font-size:.78rem;color:var(--subtext0);flex-shrink:0}.row-stats-sm{display:flex;align-items:center;gap:.4rem;flex:1;min-width:0}.row-stat-bar{flex:1;height:5px;background:var(--overlay0);border-radius:99px;overflow:hidden;min-width:40px;max-width:80px}.row-stat-fill{height:100%;border-radius:99px;transition:width .4s ease}.row-stat-label{font-size:.72rem;font-weight:600;flex-shrink:0;width:3.5rem;text-align:right}.stack-card{background:var(--surface);border:1px solid var(--overlay1);border-radius:12px;padding:1.25rem;display:flex;flex-direction:column;gap:0;transition:border-color .2s}.stack-card:hover{border-color:var(--blue-a-lg)}.stack-header{display:flex;align-items:center;gap:.75rem}.stack-icons{display:flex;gap:.2rem;flex-shrink:0}.stack-icon-chip{font-size:1.25rem;line-height:1}.stack-icon-more{font-size:.75rem;color:var(--subtext0);align-self:center;padding-left:.2rem}.stack-title{flex:1;display:flex;flex-direction:column;gap:.2rem;min-width:0}.stack-name{font-size:.95rem;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.stack-status{font-size:.72rem;font-weight:500;text-transform:uppercase;letter-spacing:.05em;color:var(--subtext1)}.status-running{color:var(--green)}.status-partial{color:var(--peach)}.status-stopped{color:var(--subtext0)}.stack-status-row{display:flex;align-items:center;gap:.6rem}.stack-countdown{font-size:.75rem;color:var(--subtext0)}.countdown-urgent{color:var(--peach);font-weight:600;animation:countdown-pulse 1.5s ease-in-out infinite}@keyframes countdown-pulse{0%,to{opacity:1}50%{opacity:.5}}.stack-actions{display:flex;gap:.5rem;align-items:center;flex-shrink:0}.btn-expand{background:transparent;border:1px solid var(--overlay1);color:var(--subtext1);border-radius:6px;padding:.3rem .55rem;font-size:.75rem;cursor:pointer;transition:background .15s,border-color .15s}.btn-expand:hover{background:var(--overlay0);border-color:var(--blue);color:var(--blue)}.btn-stack-stop,.btn-stack-start,.btn-stack-remove{background:transparent;border-radius:6px;padding:.35rem .75rem;font-size:.8rem;cursor:pointer;white-space:nowrap;transition:background .2s}.btn-stack-stop{border:1px solid var(--red);color:var(--red)}.btn-stack-stop:hover{background:var(--red-a)}.btn-stack-start{border:1px solid var(--green);color:var(--green)}.btn-stack-start:hover{background:var(--green-a)}.btn-stack-remove{border:1px solid var(--overlay1);color:var(--subtext0);padding:.35rem .55rem}.btn-stack-remove:hover{background:var(--red-a);border-color:var(--red);color:var(--red)}.confirm-label{font-size:.72rem;color:var(--peach);white-space:nowrap}.btn-stack-confirm-yes,.btn-stack-confirm-no{background:transparent;border-radius:6px;padding:.35rem .55rem;font-size:.8rem;cursor:pointer;transition:background .15s}.btn-stack-confirm-yes{border:1px solid var(--green);color:var(--green)}.btn-stack-confirm-yes:hover{background:var(--green-a)}.btn-stack-confirm-no{border:1px solid var(--overlay1);color:var(--subtext0)}.btn-stack-confirm-no:hover{background:var(--red-a);border-color:var(--red);color:var(--red)}.stack-containers{margin-top:1rem;display:flex;flex-direction:column;gap:.5rem;border-top:1px solid var(--overlay0);padding-top:1rem}.stack-container-row{display:flex;align-items:center;gap:.6rem;background:var(--mantle);border:1px solid var(--overlay0);border-radius:8px;padding:.5rem .75rem;cursor:pointer;transition:border-color .15s}.stack-container-row:hover{border-color:var(--overlay1)}.row-icon{font-size:1.1rem;flex-shrink:0}.row-info{flex:1;display:flex;flex-direction:column;gap:.1rem;min-width:0}.row-name{font-size:.8rem;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.row-status{font-size:.68rem;text-transform:uppercase;letter-spacing:.04em;font-weight:500}.row-meta{display:flex;gap:.75rem;align-items:center;flex-shrink:0}.row-port{font-size:.75rem;color:var(--blue);font-weight:600}.row-stat{font-size:.75rem;font-weight:600}.row-btns{display:flex;gap:.35rem;flex-shrink:0}.btn-restart{background:transparent;border:1px solid var(--blue);color:var(--blue);border-radius:6px;padding:.25rem .5rem;font-size:.85rem;cursor:pointer;transition:background .15s;line-height:1}.btn-restart:hover:not(:disabled){background:var(--blue-a)}.btn-restart:disabled{opacity:.4;cursor:not-allowed}.btn-logs-sm{background:transparent;border:1px solid var(--overlay1);color:var(--subtext0);border-radius:6px;padding:.25rem .5rem;font-size:.9rem;cursor:pointer;transition:all .15s;line-height:1}.btn-logs-sm:hover{background:var(--blue-a);border-color:var(--blue);color:var(--blue)}.btn-stop-sm{background:transparent;border:1px solid var(--red);color:var(--red);border-radius:6px;padding:.25rem .5rem;font-size:.8rem;cursor:pointer;transition:background .15s;line-height:1}.btn-stop-sm:hover{background:var(--red-a)}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--base);padding:1rem}.auth-card{background:var(--surface);border:1px solid var(--overlay0);border-radius:16px;padding:2.5rem 2rem;width:100%;max-width:420px;display:flex;flex-direction:column;align-items:center;gap:.5rem}.auth-logo{font-size:3rem;line-height:1;margin-bottom:.25rem}.auth-title{margin:0;font-size:1.6rem;font-weight:700;color:var(--text)}.auth-sub{margin:0 0 1rem;font-size:.82rem;color:var(--subtext0)}.auth-tabs{display:flex;width:100%;background:var(--mantle);border:1px solid var(--overlay0);border-radius:10px;padding:4px;margin-bottom:.5rem}.auth-tab{flex:1;background:transparent;border:none;border-radius:7px;color:var(--subtext0);font-size:.875rem;font-weight:500;padding:.5rem;cursor:pointer;transition:all .15s}.auth-tab.active{background:var(--overlay0);color:var(--text)}.auth-form{width:100%;display:flex;flex-direction:column;gap:.85rem;margin-top:.5rem}.field label{font-size:.8rem;color:var(--subtext1);font-weight:500}.field input{background:var(--mantle);border:1px solid var(--overlay1);border-radius:8px;color:var(--text);font-size:.9rem;padding:.55rem .75rem;outline:none;transition:border-color .15s;width:100%;box-sizing:border-box}.field input:focus{border-color:var(--blue)}.field input::placeholder{color:var(--overlay1)}.auth-error{background:var(--red-surface);border:1px solid var(--red);border-radius:8px;color:var(--red);font-size:.83rem;margin:0;padding:.55rem .75rem}.auth-submit{background:var(--blue);border:none;border-radius:8px;color:var(--surface);font-size:.95rem;font-weight:700;padding:.65rem;cursor:pointer;transition:background .2s;margin-top:.25rem}.auth-submit:hover:not(:disabled){background:var(--sky)}.auth-submit:disabled{opacity:.5;cursor:not-allowed}.auth-success{background:var(--green-surface);border:1px solid var(--green);border-radius:8px;color:var(--green);font-size:.83rem;margin:0;padding:.55rem .75rem}.auth-link{background:transparent;border:none;color:var(--subtext0);font-size:.82rem;cursor:pointer;margin-top:.25rem;text-decoration:underline;text-underline-offset:3px}.auth-link:hover{color:var(--subtext1)}.auth-back{width:100%;margin-bottom:.25rem}.auth-back button{background:transparent;border:none;color:var(--subtext0);font-size:.82rem;cursor:pointer;padding:0}.auth-back button:hover{color:var(--subtext1)}.auth-mode-title{color:var(--text);font-size:1rem;font-weight:600;margin:0 0 .5rem;align-self:flex-start}.modal-backdrop{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:100;padding:1rem}.modal{background:#1e1e2e;border:1px solid #313244;border-radius:16px;width:100%;max-width:600px;max-height:90vh;overflow-y:auto;display:flex;flex-direction:column}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid #313244;position:sticky;top:0;background:#1e1e2e;z-index:1}.modal-header h2{margin:0;font-size:1.05rem;color:#cdd6f4}.modal-close{background:transparent;border:none;color:#6c7086;font-size:1rem;cursor:pointer;padding:0;line-height:1}.modal-close:hover{color:#cdd6f4}.modal-form{padding:1.25rem 1.5rem;display:flex;flex-direction:column;gap:1rem}.field{display:flex;flex-direction:column;gap:.35rem}.field label{font-size:.8rem;color:#a6adc8;font-weight:500}.field-hint{color:#6c7086;font-weight:400}.field input,.field textarea{background:#181825;border:1px solid #45475a;border-radius:8px;color:#cdd6f4;font-size:.875rem;padding:.5rem .75rem;outline:none;font-family:inherit;resize:vertical;transition:border-color .15s}.field input:focus,.field textarea:focus{border-color:#89b4fa}.field input::placeholder,.field textarea::placeholder{color:#45475a}.field-row{display:flex;gap:.75rem}.field-row .field{flex:1}.containers-section{display:flex;flex-direction:column;gap:.75rem}.containers-header{display:flex;align-items:center;justify-content:space-between}.section-label{font-size:.85rem;font-weight:600;color:#cdd6f4}.btn-add-container{background:transparent;border:1px dashed #45475a;border-radius:6px;color:#89b4fa;font-size:.8rem;padding:.3rem .75rem;cursor:pointer;transition:all .15s}.btn-add-container:hover{border-color:#89b4fa;background:#89b4fa15}.container-config{background:#181825;border:1px solid #313244;border-radius:10px;padding:1rem;display:flex;flex-direction:column;gap:.75rem}.container-config-header{display:flex;align-items:center;justify-content:space-between}.container-index{font-size:.8rem;font-weight:600;color:#89b4fa}.btn-remove{background:transparent;border:none;color:#6c7086;font-size:.8rem;cursor:pointer;padding:0}.btn-remove:hover{color:#f38ba8}.modal-error{background:#2d1b22;border:1px solid #f38ba8;border-radius:8px;color:#f38ba8;font-size:.83rem;margin:0;padding:.55rem .75rem}.modal-actions{display:flex;gap:.75rem;justify-content:flex-end;padding-top:.25rem}.btn-cancel{background:transparent;border:1px solid #45475a;border-radius:8px;color:#a6adc8;font-size:.875rem;padding:.55rem 1.25rem;cursor:pointer;transition:all .15s}.btn-cancel:hover{border-color:#cdd6f4;color:#cdd6f4}.btn-create{background:#89b4fa;border:none;border-radius:8px;color:#1e1e2e;font-size:.875rem;font-weight:700;padding:.55rem 1.25rem;cursor:pointer;transition:background .2s}.btn-create:hover:not(:disabled){background:#74c7ec}.btn-create:disabled{opacity:.5;cursor:not-allowed}.templates-page{display:flex;flex-direction:column;gap:1.5rem;padding:1.5rem 2rem;max-width:1400px;margin:0 auto;width:100%;box-sizing:border-box}.tp-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem}.tp-header h2{margin:0 0 .25rem;font-size:1.2rem;color:var(--text)}.tp-sub{margin:0;font-size:.85rem;color:var(--subtext0)}.btn-new-template{background:var(--blue);border:none;border-radius:8px;color:var(--surface);font-size:.875rem;font-weight:700;padding:.55rem 1.1rem;cursor:pointer;transition:background .2s;white-space:nowrap;flex-shrink:0}.btn-new-template:hover{background:var(--sky)}.tp-layout{display:flex;gap:1.5rem;align-items:flex-start}.tp-sidebar{width:260px;flex-shrink:0;display:flex;flex-direction:column;gap:.5rem}.favorites-header{display:flex;align-items:center;justify-content:space-between;font-size:.85rem;font-weight:600;color:var(--text);background:var(--surface);border:1px solid var(--overlay0);border-radius:10px 10px 0 0;padding:.75rem 1rem}.fav-count{background:var(--overlay0);color:var(--subtext1);border-radius:99px;padding:.1rem .55rem;font-size:.75rem}.favorites-drop-zone{background:var(--surface);border:1px solid var(--overlay0);border-top:none;border-radius:0 0 10px 10px;padding:.5rem;min-height:200px;transition:border-color .15s,background .15s}.favorites-drop-zone.drag-over{border-color:var(--blue);background:var(--blue)0d}.fav-empty{color:var(--overlay1);font-size:.82rem;text-align:center;padding:2rem 1rem;margin:0;border:1px dashed var(--overlay0);border-radius:8px}.fav-item{display:flex;align-items:center;gap:.5rem;background:var(--mantle);border:1px solid var(--overlay0);border-radius:8px;padding:.5rem .6rem;margin-bottom:.4rem;cursor:grab;-webkit-user-select:none;user-select:none;transition:border-color .15s}.fav-item:hover{border-color:var(--overlay1)}.fav-item:active{cursor:grabbing}.fav-drag-handle{color:var(--overlay1);font-size:1rem;flex-shrink:0}.fav-label{flex:1;font-size:.85rem;color:var(--text);text-transform:capitalize}.fav-remove{background:transparent;border:none;color:var(--overlay1);font-size:.75rem;cursor:pointer;padding:0;flex-shrink:0;line-height:1}.fav-remove:hover{color:var(--red)}.fav-trash-zone{border:1px dashed var(--red);border-radius:8px;color:var(--red);font-size:.8rem;text-align:center;padding:.75rem;opacity:.7;transition:opacity .15s}.fav-trash-zone:hover{opacity:1}.tp-library{flex:1;display:flex;flex-direction:column;gap:1.25rem}.library-section-title{margin:0 0 .75rem;font-size:.9rem;font-weight:600;color:var(--subtext1);text-transform:uppercase;letter-spacing:.06em}.template-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.875rem}.template-card{background:var(--surface);border:1px solid var(--overlay0);border-radius:12px;padding:1.1rem;display:flex;flex-direction:column;gap:.4rem;cursor:grab;-webkit-user-select:none;user-select:none;transition:border-color .15s,transform .1s}.template-card:hover{border-color:var(--overlay1);transform:translateY(-1px)}.template-card:active{cursor:grabbing}.template-card.is-favorite{border-color:var(--blue)44}.tc-icon{font-size:1.75rem;line-height:1}.tc-name{font-size:.95rem;font-weight:600;color:var(--text);text-transform:capitalize}.tc-type{font-size:.72rem;color:var(--subtext0);text-transform:uppercase;letter-spacing:.05em}.tc-desc{font-size:.8rem;color:var(--subtext0);line-height:1.4}.tc-containers{font-size:.75rem;color:var(--subtext1);background:var(--mantle);border-radius:6px;padding:.3rem .5rem}.tc-actions{display:flex;gap:.4rem;margin-top:.25rem}.tc-btn{flex:1;background:var(--mantle);border:1px solid var(--overlay1);border-radius:6px;color:var(--subtext1);font-size:.75rem;padding:.3rem .5rem;cursor:pointer;transition:all .15s}.tc-btn:hover{border-color:var(--blue);color:var(--blue)}.tc-btn-remove{flex:1;background:var(--blue)15;border:1px solid var(--blue);border-radius:6px;color:var(--blue);font-size:.75rem;padding:.3rem .5rem;cursor:pointer}.tc-btn-delete{background:transparent;border:1px solid var(--overlay1);border-radius:6px;color:var(--subtext0);font-size:.75rem;padding:.3rem .5rem;cursor:pointer;transition:all .15s}.tc-btn-delete:hover{border-color:var(--red);color:var(--red)}.tc-btn-confirm-yes,.tc-btn-confirm-no{background:transparent;border-radius:6px;padding:.3rem .5rem;font-size:.8rem;cursor:pointer;transition:all .15s}.empty-custom{text-align:center;color:var(--subtext0);font-size:.9rem;padding:2rem;border:1px dashed var(--overlay0);border-radius:12px;display:flex;flex-direction:column;align-items:center;gap:1rem}.empty-custom p{margin:0}.custom-card{border-color:var(--overlay1)44}.team-card{border-color:var(--mauve)44}.team-card:hover{border-color:var(--mauve)}.team-card.is-favorite{border-color:var(--mauve)88}.tc-creator{font-size:.72rem;color:var(--mauve);font-weight:500}.library-section-header{display:flex;align-items:baseline;gap:.75rem;margin-bottom:.75rem}.library-section-header .library-section-title{margin-bottom:0}.team-section-hint{font-size:.75rem;color:var(--subtext0)}.tsb-backdrop{position:fixed;inset:0;background:#0000008c;display:flex;align-items:center;justify-content:center;z-index:200;padding:1rem}.tsb-modal{background:var(--base);border:1px solid var(--overlay0);border-radius:14px;width:100%;max-width:900px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}.tsb-header{display:flex;align-items:center;justify-content:space-between;padding:.9rem 1.25rem;border-bottom:1px solid var(--overlay0);flex-shrink:0}.tsb-title{font-size:1rem;font-weight:700;color:var(--text)}.tsb-close{background:transparent;border:none;color:var(--subtext0);font-size:.9rem;cursor:pointer;padding:.25rem .4rem;border-radius:4px;transition:color .15s}.tsb-close:hover{color:var(--red)}.tsb-body{display:grid;grid-template-columns:260px 1fr;gap:0;overflow:hidden;flex:1;min-height:0}.tsb-left{display:flex;flex-direction:column;gap:.6rem;padding:1.1rem 1rem;border-right:1px solid var(--overlay0);background:var(--mantle);overflow-y:auto}.tsb-right{display:flex;flex-direction:column;gap:.75rem;padding:1.1rem;overflow-y:auto;background:var(--base)}.tsb-section-label{font-size:.7rem;color:var(--subtext0);text-transform:uppercase;letter-spacing:.05em}.tsb-hint{font-size:.8rem;color:var(--overlay2);margin:0}.tsb-error{font-size:.82rem;color:var(--red);background:color-mix(in srgb,var(--red) 8%,transparent);border:1px solid var(--red);border-radius:6px;padding:.45rem .7rem;margin:0}.tsb-field-row{display:flex;gap:.5rem}.tsb-field{display:flex;flex-direction:column;gap:.3rem}.tsb-label{font-size:.75rem;color:var(--subtext1)}.tsb-input{background:var(--surface);border:1px solid var(--overlay0);border-radius:7px;color:var(--text);font-size:.88rem;padding:.45rem .6rem;outline:none;width:100%;box-sizing:border-box;transition:border-color .15s}.tsb-input:focus{border-color:var(--blue)}.tsb-input::placeholder{color:var(--overlay1)}.tsb-container-summary{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.3rem}.tsb-summary-item{display:flex;align-items:center;gap:.4rem;background:var(--surface);border:1px solid var(--overlay0);border-radius:6px;padding:.3rem .5rem;font-size:.78rem}.tsb-summary-icon{flex-shrink:0;font-size:.9rem}.tsb-summary-name{font-weight:600;color:var(--text);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tsb-summary-image{color:var(--subtext0);font-family:monospace;font-size:.72rem;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-left:auto}.tsb-btn-submit{background:var(--mauve);border:none;border-radius:8px;color:var(--base);font-size:.88rem;font-weight:700;padding:.6rem .9rem;cursor:pointer;transition:background .15s}.tsb-btn-submit:hover:not(:disabled){background:var(--sky)}.tsb-btn-submit:disabled{opacity:.45;cursor:not-allowed}.tsb-btn-cancel{background:transparent;border:1px solid var(--overlay1);border-radius:8px;color:var(--subtext1);font-size:.82rem;padding:.5rem .9rem;cursor:pointer;transition:border-color .15s,color .15s}.tsb-btn-cancel:hover{border-color:var(--overlay2);color:var(--text)}.tsb-palette{display:flex;flex-wrap:wrap;gap:.35rem}.tsb-chip{display:flex;align-items:center;gap:.3rem;background:var(--mantle);border:1px solid var(--overlay0);border-radius:6px;color:var(--subtext1);padding:.28rem .55rem;font-size:.78rem;cursor:grab;-webkit-user-select:none;user-select:none;white-space:nowrap;transition:border-color .15s,background .15s,color .15s}.tsb-chip:hover{border-color:var(--mauve);color:var(--text);background:var(--surface)}.tsb-chip:active{cursor:grabbing}.tsb-chip-label{font-weight:500}.tsb-chip-multi{background:var(--overlay0);color:var(--subtext1);font-size:.62rem;border-radius:99px;padding:.05rem .3rem;font-weight:700;line-height:1.4}.tsb-drop-zone{flex:1;min-height:120px;border:1.5px dashed var(--overlay1);border-radius:10px;padding:.6rem;display:flex;flex-direction:column;gap:.45rem;transition:border-color .15s,background .15s}.tsb-dz-over{border-color:var(--mauve);background:color-mix(in srgb,var(--mauve) 6%,transparent)}.tsb-dz-hint{margin:auto;font-size:.82rem;color:var(--overlay2);text-align:center;pointer-events:none}.tsb-item{background:var(--mantle);border:1px solid var(--overlay0);border-radius:8px;overflow:hidden}.tsb-item-header{display:flex;align-items:center;gap:.45rem;padding:.45rem .6rem}.tsb-item-icon{font-size:1rem;flex-shrink:0}.tsb-item-name{font-size:.82rem;font-weight:600;color:var(--text);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tsb-item-image{font-size:.72rem;color:var(--subtext0);font-family:monospace;max-width:8rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex-shrink:0}.tsb-item-btn{background:transparent;border:none;cursor:pointer;border-radius:4px;padding:.15rem .35rem;font-size:.75rem;flex-shrink:0;color:var(--subtext0);transition:color .15s}.tsb-item-btn:hover{color:var(--mauve)}.tsb-item-remove:hover{color:var(--red)!important}.tsb-item-config{border-top:1px solid var(--overlay0);padding:.6rem .75rem;display:flex;flex-direction:column;gap:.4rem}.tsb-cfg-row{display:flex;align-items:center;gap:.5rem}.tsb-cfg-label{font-size:.75rem;color:var(--subtext0);width:5.5rem;flex-shrink:0}.tsb-cfg-input{flex:1;background:var(--surface);border:1px solid var(--overlay0);border-radius:6px;color:var(--text);font-size:.82rem;padding:.3rem .5rem;outline:none;min-width:0;transition:border-color .15s}.tsb-cfg-input:focus{border-color:var(--mauve)}.tsb-cfg-input-sm{max-width:120px;flex:0 0 120px}.tsb-env-title{font-size:.7rem;color:var(--subtext0);text-transform:uppercase;letter-spacing:.04em;margin-top:.1rem}.tsb-env-row{display:flex;align-items:center;gap:.35rem}.tsb-env-key{flex:0 0 38%;font-family:monospace;font-size:.78rem}.tsb-env-val{flex:1;font-family:monospace;font-size:.78rem}.tsb-env-sep{color:var(--subtext0);font-size:.9rem;flex-shrink:0}.tsb-btn-add-env{background:transparent;border:1px dashed var(--overlay1);border-radius:6px;color:var(--subtext0);padding:.25rem .55rem;font-size:.75rem;cursor:pointer;align-self:flex-start;transition:border-color .15s,color .15s}.tsb-btn-add-env:hover{border-color:var(--mauve);color:var(--mauve)}.teams-page{display:flex;flex-direction:column;gap:1.5rem;padding:1.5rem 2rem;max-width:1400px;margin:0 auto;width:100%;box-sizing:border-box}.teams-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem}.teams-header h2{margin:0 0 .25rem;font-size:1.2rem;color:var(--text)}.teams-sub{margin:0;font-size:.85rem;color:var(--subtext0)}.team-selector-bar{display:flex;align-items:center;justify-content:space-between;gap:1rem;background:var(--surface);border:1px solid var(--overlay0);border-radius:10px;padding:.65rem 1rem}.team-selector-left{display:flex;align-items:center;gap:.6rem}.team-selector-label{font-size:.85rem;color:var(--subtext0);font-weight:600;white-space:nowrap}.team-dropdown{background:var(--mantle);border:1px solid var(--overlay0);border-radius:8px;color:var(--text);font-size:.9rem;font-weight:500;padding:.4rem .75rem;cursor:pointer;outline:none;transition:border-color .15s;min-width:220px}.team-dropdown:focus{border-color:var(--blue)}.btn-create-team{background:var(--blue);border:none;border-radius:8px;color:var(--surface);font-size:.875rem;font-weight:700;padding:.55rem 1.1rem;cursor:pointer;transition:background .2s;white-space:nowrap;flex-shrink:0}.btn-create-team:hover{background:var(--sky)}.btn-delete-team{background:transparent;border:1px solid var(--overlay1);border-radius:8px;color:var(--subtext0);font-size:.8rem;padding:.4rem .75rem;cursor:pointer;transition:all .15s}.btn-delete-team:hover{border-color:var(--red);color:var(--red)}.teams-empty{text-align:center;padding:4rem 2rem;display:flex;flex-direction:column;align-items:center;gap:.75rem}.teams-empty-icon{font-size:3rem}.teams-empty-title{margin:0;font-size:1.1rem;font-weight:600;color:var(--text)}.teams-empty-sub{margin:0;font-size:.875rem;color:var(--subtext0)}.team-body{display:grid;grid-template-columns:280px 1fr;gap:1.25rem;align-items:start}.team-loading{grid-column:1 / -1;display:flex;justify-content:center;padding:3rem}.panel-header{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:var(--surface);border:1px solid var(--overlay0);border-radius:10px 10px 0 0;border-bottom:none}.panel-title{font-size:.85rem;font-weight:600;color:var(--text);flex:1}.panel-count{background:var(--overlay0);color:var(--subtext1);border-radius:99px;padding:.1rem .55rem;font-size:.75rem}.team-members-panel{display:flex;flex-direction:column;border:1px solid var(--overlay0);border-radius:10px;overflow:hidden}.members-list{background:var(--surface);display:flex;flex-direction:column}.member-row{display:flex;align-items:center;gap:.65rem;padding:.6rem 1rem;border-bottom:1px solid var(--overlay0);transition:background .12s}.member-row:hover{background:var(--mantle)}.member-row:last-child{border-bottom:none}.member-avatar{width:2rem;height:2rem;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:700;flex-shrink:0}.member-info{display:flex;flex-direction:column;gap:.05rem;flex:1;min-width:0}.member-name{font-size:.875rem;color:var(--text);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.member-handle{font-size:.72rem;color:var(--subtext0)}.member-role{font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;border-radius:4px;padding:.15rem .4rem;flex-shrink:0}.role-owner{background:var(--blue-a);color:var(--blue)}.role-member{background:var(--overlay0);color:var(--subtext1)}.btn-remove-member{background:transparent;border:none;color:var(--overlay1);font-size:.72rem;cursor:pointer;padding:.2rem .4rem;border-radius:4px;flex-shrink:0;transition:all .12s;white-space:nowrap}.btn-remove-member:hover{color:var(--red);background:var(--red-a)}.add-member-form{display:flex;flex-direction:column;gap:.4rem;padding:.65rem .75rem;background:var(--mantle);border-top:1px solid var(--overlay0)}.add-member-input{flex:1;background:var(--surface);border:1px solid var(--overlay0);border-radius:6px;color:var(--text);font-size:.82rem;padding:.4rem .6rem;outline:none;transition:border-color .15s}.add-member-input:focus{border-color:var(--blue)}.add-member-input::placeholder{color:var(--overlay1)}.btn-add-member{background:var(--blue);border:none;border-radius:6px;color:var(--surface);font-size:.78rem;font-weight:600;padding:.4rem .65rem;cursor:pointer;width:100%;transition:background .15s}.btn-add-member:hover:not(:disabled){background:var(--sky)}.btn-add-member:disabled{opacity:.5;cursor:default}.team-templates-panel{border:1px solid var(--overlay0);border-radius:10px;overflow:hidden}.team-templates-panel .panel-header{border-radius:0}.btn-add-template{background:var(--mauve);border:none;border-radius:6px;color:var(--base);font-size:.78rem;font-weight:700;padding:.3rem .7rem;cursor:pointer;margin-left:auto;transition:background .15s;white-space:nowrap}.btn-add-template:hover{background:var(--sky)}.templates-empty{background:var(--surface);padding:2rem;text-align:center;color:var(--subtext0);font-size:.875rem;display:flex;flex-direction:column;align-items:center;gap:1rem}.templates-empty p{margin:0}.team-templates-grid{background:var(--surface);display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.875rem;padding:1rem}.team-tmpl-card{background:var(--mantle);border:1px solid var(--overlay0);border-radius:10px;padding:1rem;display:flex;flex-direction:column;gap:.35rem;transition:border-color .15s}.team-tmpl-card:hover{border-color:var(--mauve)}.ttc-icon{font-size:1.75rem;line-height:1}.ttc-name{font-size:.95rem;font-weight:600;color:var(--text)}.ttc-desc{font-size:.78rem;color:var(--subtext0);line-height:1.4}.ttc-creator{font-size:.72rem;color:var(--mauve);font-weight:500}.ttc-containers{font-size:.72rem;color:var(--subtext1);background:var(--surface);border-radius:5px;padding:.25rem .45rem;margin-top:.1rem}.ttc-actions{display:flex;gap:.4rem;margin-top:.25rem;align-items:center}.ttc-btn-edit{background:transparent;border:1px solid var(--overlay1);border-radius:6px;color:var(--subtext0);font-size:.72rem;padding:.25rem .5rem;cursor:pointer;transition:all .15s}.ttc-btn-edit:hover{border-color:var(--mauve);color:var(--mauve)}.ttc-btn-delete{background:transparent;border:1px solid var(--overlay1);border-radius:6px;color:var(--subtext0);font-size:.72rem;padding:.25rem .5rem;cursor:pointer;transition:all .15s}.ttc-btn-delete:hover{border-color:var(--red);color:var(--red)}.tc-confirm-label{font-size:.72rem;color:var(--peach)}.tc-btn-confirm-yes,.tc-btn-confirm-no{background:transparent;border-radius:6px;padding:.25rem .5rem;font-size:.78rem;cursor:pointer;transition:all .15s}.tc-btn-confirm-yes{border:1px solid var(--green);color:var(--green)}.tc-btn-confirm-yes:hover{background:var(--green-a)}.tc-btn-confirm-no{border:1px solid var(--overlay1);color:var(--subtext0)}.tc-btn-confirm-no:hover{border-color:var(--red);color:var(--red)}.create-team-input{width:100%;box-sizing:border-box;background:var(--mantle);border:1px solid var(--overlay0);border-radius:8px;color:var(--text);font-size:.9rem;padding:.55rem .75rem;outline:none;transition:border-color .15s;margin-bottom:.25rem}.create-team-input:focus{border-color:var(--blue)}.create-team-input::placeholder{color:var(--overlay1)}.profile-section-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--subtext0);margin-bottom:.5rem}.profile-info-grid{display:grid;grid-template-columns:7rem 1fr;gap:.4rem .75rem;font-size:.88rem}.profile-info-key{color:var(--subtext0)}.profile-info-val{color:var(--text);font-weight:500}.profile-prefs{display:flex;flex-direction:column;gap:.1rem}.pref-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.6rem .75rem;border-radius:8px;cursor:pointer;transition:background .15s}.pref-row:hover{background:var(--mantle)}.pref-text{display:flex;flex-direction:column;gap:.15rem}.pref-label{font-size:.88rem;color:var(--text);font-weight:500}.pref-desc{font-size:.78rem;color:var(--subtext0)}.theme-toggle-row{display:flex;gap:.5rem}.theme-btn{flex:1;background:var(--mantle);border:1px solid var(--overlay0);border-radius:8px;color:var(--subtext1);font-size:.875rem;padding:.5rem 1rem;cursor:pointer;transition:all .15s}.theme-btn:hover{border-color:var(--overlay1);color:var(--text)}.theme-btn.active{background:var(--overlay0);border-color:var(--blue);color:var(--blue);font-weight:600}.toggle{width:2.5rem;height:1.4rem;background:var(--overlay0);border-radius:99px;position:relative;flex-shrink:0;transition:background .2s;cursor:pointer}.toggle-on{background:var(--blue)}.toggle-thumb{position:absolute;top:3px;left:3px;width:1rem;height:1rem;background:var(--text);border-radius:50%;transition:transform .2s}.toggle-on .toggle-thumb{transform:translate(1.1rem)}.dash-stats{display:flex;align-items:center;gap:.25rem;background:var(--surface);border:1px solid var(--overlay0);border-radius:10px;padding:.6rem 1rem;flex-wrap:wrap}.stat-card{display:flex;flex-direction:column;align-items:center;padding:.3rem .9rem;gap:.15rem;min-width:70px}.stat-card-value{font-size:1.35rem;font-weight:700;color:var(--text);line-height:1}.stat-green{color:var(--green)}.stat-red{color:var(--red)}.stat-blue{color:var(--blue)}.stat-card-label{font-size:.72rem;color:var(--subtext0);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}.stat-card-sub{font-size:.68rem;color:var(--overlay1);text-transform:none;letter-spacing:0}.stat-divider{width:1px;height:2.5rem;background:var(--overlay0);margin:0 .5rem;flex-shrink:0}.stat-card-templates{align-items:flex-start;min-width:0}.stat-card-label-top{margin-bottom:.2rem}.stat-template-list{display:flex;gap:.4rem;flex-wrap:wrap}.stat-template-chip{background:var(--overlay0);border-radius:99px;padding:.1rem .5rem;font-size:.72rem;color:var(--subtext1);display:flex;align-items:center;gap:.3rem}.stat-template-count{background:var(--overlay1);border-radius:99px;padding:0 .3rem;font-size:.68rem;font-weight:700;color:var(--text)}.app{min-height:100vh;display:flex;flex-direction:column;background:var(--base);color:var(--text)}.app-header{display:flex;align-items:center;gap:1rem;padding:.75rem 2rem;background:var(--surface);border-bottom:1px solid var(--overlay0)}.app-nav{display:flex;gap:.25rem;background:var(--mantle);border:1px solid var(--overlay0);border-radius:8px;padding:3px;margin-left:.5rem}.nav-btn{background:transparent;border:none;border-radius:6px;color:var(--subtext0);font-size:.85rem;font-weight:500;padding:.35rem .85rem;cursor:pointer;transition:all .15s}.nav-btn:hover{color:var(--text)}.nav-btn.active{background:var(--overlay0);color:var(--text)}.header-logo{font-size:2rem;line-height:1}.header-title{margin:0;font-size:1.4rem;font-weight:700;color:var(--text)}.header-sub{margin:0;font-size:.8rem;color:var(--subtext0)}.header-badge{margin-left:auto;display:flex;align-items:center;gap:.5rem;font-size:.8rem;color:var(--subtext1);background:var(--mantle);border:1px solid var(--overlay0);border-radius:99px;padding:.3rem .85rem}.status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.dot-ok{background:var(--green);box-shadow:0 0 6px var(--green)}.dot-error{background:var(--red);box-shadow:0 0 6px var(--red)}.header-user{display:flex;align-items:center;gap:.5rem;margin-left:.75rem;padding-left:.75rem;border-left:1px solid var(--overlay0)}.user-name{font-size:.85rem;font-weight:600;color:var(--text)}.user-handle{font-size:.78rem;color:var(--subtext0)}.btn-profile{background:transparent;border:none;cursor:pointer;display:flex;flex-direction:row;align-items:center;gap:.5rem;padding:.25rem .4rem;border-radius:6px;transition:background .15s}.btn-profile>div{display:flex;flex-direction:column;align-items:flex-start;gap:.1rem}.btn-profile:hover{background:var(--overlay0)}.btn-logout{background:transparent;border:1px solid var(--overlay1);border-radius:6px;color:var(--subtext1);font-size:.78rem;padding:.25rem .6rem;cursor:pointer;transition:all .15s}.btn-logout:hover{border-color:var(--red);color:var(--red)}.error-banner{background:var(--red-surface);border-bottom:1px solid var(--red);color:var(--red);padding:.75rem 2rem;font-size:.875rem}.app-main{flex:1;display:flex;gap:1.5rem;padding:1.5rem 2rem;max-width:1400px;width:100%;margin:0 auto;box-sizing:border-box}.app-sidebar{width:340px;flex-shrink:0}.app-content{flex:1;display:flex;flex-direction:column;gap:1rem}.content-header{display:flex;align-items:center;gap:.75rem}.section-block{display:flex;flex-direction:column;gap:.75rem}.section-label{font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--subtext0);display:flex;align-items:center;gap:.5rem}.section-count{background:var(--overlay0);color:var(--subtext1);border-radius:99px;padding:.1rem .5rem;font-size:.72rem;font-weight:600}.section-divider{border:none;border-top:1px solid var(--overlay0);margin:.25rem 0}.content-header h2{margin:0;font-size:1.1rem;color:var(--text)}.container-count{background:var(--overlay0);color:var(--subtext1);border-radius:99px;padding:.1rem .6rem;font-size:.8rem;font-weight:600}.hint{color:var(--subtext0);font-size:.9rem;margin:0}.loading-spinner-wrap{display:flex;justify-content:center;padding:4rem 2rem}.loading-spinner{width:2rem;height:2rem;border:2px solid var(--overlay0);border-top-color:var(--blue);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;padding:4rem 2rem;text-align:center}.empty-state-icon{font-size:3rem;line-height:1;opacity:.4}.empty-state-title{margin:0;font-size:1rem;font-weight:600;color:var(--subtext0)}.empty-state-sub{margin:0;font-size:.85rem;color:var(--overlay1)}.toolbar{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center;background:var(--surface);border:1px solid var(--overlay0);border-radius:10px;padding:.75rem 1rem}.search-wrapper{display:flex;align-items:center;background:var(--mantle);border:1px solid var(--overlay1);border-radius:8px;padding:0 .6rem;gap:.4rem;min-width:200px;flex:1;max-width:320px}.search-wrapper:focus-within{border-color:var(--blue)}.search-icon{font-size:.85rem;flex-shrink:0}.search-input{background:transparent;border:none;color:var(--text);font-size:.875rem;padding:.4rem 0;flex:1;outline:none}.search-input::placeholder{color:var(--subtext0)}.search-clear{background:transparent;border:none;color:var(--subtext0);cursor:pointer;font-size:.75rem;padding:0;line-height:1}.search-clear:hover{color:var(--text)}.filter-group{display:flex;align-items:center;gap:.35rem;flex-wrap:nowrap;overflow-x:auto;max-width:100%;scrollbar-width:thin;scrollbar-color:var(--overlay1) transparent;padding-bottom:2px}.filter-label{font-size:.78rem;color:var(--subtext0);margin-right:.1rem;flex-shrink:0}.filter-btn{background:var(--mantle);border:1px solid var(--overlay0);border-radius:6px;color:var(--subtext1);font-size:.78rem;padding:.25rem .6rem;cursor:pointer;transition:all .15s;text-transform:capitalize;flex-shrink:0}.filter-btn:hover{border-color:var(--overlay1);color:var(--text)}.filter-btn.active{background:var(--overlay0);border-color:var(--blue);color:var(--blue)}.filter-status-running.active{border-color:var(--green);color:var(--green)}.filter-status-paused.active{border-color:var(--peach);color:var(--peach)}.filter-status-exited.active{border-color:var(--red);color:var(--red)}.container-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.view-toggle{display:flex;background:var(--mantle);border:1px solid var(--overlay1);border-radius:8px;padding:3px;gap:0}.view-btn{background:transparent;border:none;border-radius:6px;color:var(--subtext0);padding:.3rem .6rem;font-size:1rem;cursor:pointer;transition:background .15s,color .15s}.view-btn.active{background:var(--overlay0);color:var(--text)}.container-grid.grid-list{display:flex;flex-direction:column;gap:.4rem}.container-grid .stack-card--grid{grid-column:1 / -1}
