.app-layout{display:flex;height:100vh}.mobile-topbar{display:none}.desktop-topbar{display:flex;justify-content:flex-end;margin:-12px 0 18px}.account-menu{position:relative;z-index:80}.account-trigger{display:inline-flex;align-items:center;gap:8px;border:0;background:transparent;color:var(--text)}.account-avatar{width:38px;height:38px;border-radius:50%;background:#d8e7f3;color:#173552;display:inline-flex;align-items:center;justify-content:center;font-weight:800;font-size:16px}.account-chevron{color:var(--text-muted);font-size:16px;transform:translateY(1px)}.account-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:230px;padding:8px 0;background:var(--card-bg);border:1px solid var(--border);border-radius:4px;box-shadow:0 10px 28px #1735522e}.account-slug,.account-menu-item{display:flex;align-items:center;width:100%;min-height:34px;padding:8px 14px;border:0;background:transparent;color:#173552;font-size:13px;text-align:left;text-decoration:none}.account-slug{justify-content:space-between;gap:10px;color:#b42318;font-family:Menlo,Monaco,Courier New,monospace}.account-slug span:first-child{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.copy-icon{color:#426b8c;font-family:system-ui,sans-serif}.account-menu-item:hover,.account-slug:hover{background:#f4f7fa;text-decoration:none}.app-logo,.sidebar-brand{text-decoration:none}.app-logo{align-items:center;color:#fff;font-size:14px;font-weight:800;gap:8px}.logo-mark{width:28px;height:28px;border-radius:9px;display:inline-block;object-fit:cover}.sidebar{width:240px;background:var(--sidebar-bg);display:flex;flex-direction:column;color:var(--sidebar-text);flex-shrink:0}.sidebar-brand{display:block;padding:20px;border-bottom:1px solid rgba(255,255,255,.08)}.sidebar-brand h2{display:flex;align-items:center;gap:9px;color:#fff;font-size:18px;font-weight:600}.sidebar-brand:hover h2{color:var(--sidebar-active)}.sidebar-version{font-size:11px;color:var(--sidebar-text);opacity:.6}.sidebar-nav{flex:1;padding:12px 0;overflow-y:auto}.nav-section{padding:16px 20px 6px;font-size:11px;text-transform:uppercase;letter-spacing:1px;color:var(--sidebar-text);opacity:.5;font-weight:600}.nav-item{display:flex;align-items:center;gap:12px;padding:10px 20px;color:var(--sidebar-text);font-size:14px;transition:all .15s;border-left:3px solid transparent;text-decoration:none}.nav-item:hover{background:#ffffff0f;color:#fff;text-decoration:none}.nav-item.active{background:#2c95d626;color:var(--sidebar-active);border-left-color:var(--sidebar-active)}.device-subnav{margin-top:8px;background:#00000029;border-top:1px solid rgba(255,255,255,.08);border-bottom:1px solid rgba(255,255,255,.08)}.device-subnav-title{display:flex;align-items:center;gap:8px;padding:12px 20px;color:#fff;font-size:13px;font-weight:700;overflow:hidden}.device-subnav-title span:last-child{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.device-dot{width:8px;height:8px;border-radius:50%;background:var(--danger);flex-shrink:0}.device-dot.online{background:var(--success)}.subnav-item{display:flex;align-items:center;gap:10px;padding:13px 20px 13px 28px;border-top:1px solid rgba(255,255,255,.07);color:#d9e4ef;font-size:13px;font-weight:600;text-decoration:none}.subnav-item:hover{background:#ffffff0f;color:#fff;text-decoration:none}.subnav-item.active{background:#eef3f8;color:#173552;border-left:3px solid var(--primary);padding-left:25px}.subnav-item span{width:22px;font-size:11px;font-weight:800;letter-spacing:-.03em}.sidebar-user{padding:16px 20px;border-top:1px solid rgba(255,255,255,.08)}.user-info{display:flex;align-items:center;gap:10px;margin-bottom:10px}.user-avatar{width:34px;height:34px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px;flex-shrink:0}.user-details{overflow:hidden}.user-email{font-size:13px;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-size:11px;color:var(--sidebar-text);opacity:.7}.logout-btn{width:100%;padding:8px;background:#ffffff14;border:1px solid rgba(255,255,255,.12);border-radius:var(--radius);color:var(--sidebar-text);font-size:13px;transition:all .15s}.logout-btn:hover{background:#ffffff24;color:#fff}.main-content{flex:1;overflow-y:auto;padding:32px}@media (max-width: 768px){.app-layout{display:block;height:auto;min-height:100vh}.mobile-topbar{position:sticky;top:0;z-index:50;display:flex;align-items:center;height:54px;padding:0 16px;background:var(--sidebar-bg);box-shadow:0 1px #ffffff14;justify-content:space-between}.desktop-topbar{display:none}.mobile-topbar .account-avatar{width:34px;height:34px}.mobile-topbar .account-chevron{color:#d9e4ef}.mobile-topbar .app-logo{display:inline-flex}.sidebar{display:none}.main-content{padding:16px}}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#1a2332,#2a3f54)}.login-card{width:100%;max-width:400px;padding:40px;background:var(--card-bg);border-radius:12px;box-shadow:0 4px 24px #0003}.login-header{text-align:center;margin-bottom:28px}.login-header h1{font-size:26px;color:var(--text);font-weight:700}.login-header p{color:var(--text-muted);margin-top:6px}.login-error{background:#fde8e8;color:var(--danger);padding:10px 14px;border-radius:var(--radius);margin-bottom:16px;font-size:13px}.login-note{color:var(--text-muted);font-size:14px;line-height:1.5;margin-bottom:20px}.btn-github{display:flex;align-items:center;justify-content:center;gap:9px;width:100%;height:42px;padding:0 16px;margin-bottom:16px;background:#fff;color:#1f2937;text-decoration:none;border:1px solid #d7dee8;border-radius:var(--radius);box-shadow:0 1px 2px #1018200d;font-size:14px;font-weight:600;text-align:center}.btn-github svg{width:18px;height:18px;flex:0 0 auto}.btn-github:hover{background:#f8fafc;color:#111827;border-color:#c8d2df;box-shadow:0 2px 8px #10182014}.login-divider{display:flex;align-items:center;gap:12px;margin:0 0 18px;color:var(--text-muted);font-size:12px;text-transform:uppercase;letter-spacing:.08em}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:var(--border)}.page-title{font-size:24px;font-weight:700;margin-bottom:24px;color:var(--text)}.alert{padding:12px 16px;border-radius:var(--radius);margin-bottom:16px;font-size:13px}.alert-error{background:#fde8e8;color:var(--danger)}.alert-success{background:#e8f5e9;color:var(--success)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px;margin-bottom:24px}.stat-card{background:var(--card-bg);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow);text-decoration:none;color:var(--text);transition:box-shadow .15s}.stat-card:hover{box-shadow:0 2px 8px #00000026;text-decoration:none}.stat-card:focus-visible{outline:2px solid var(--primary);outline-offset:3px}.stat-value{font-size:32px;font-weight:700;color:var(--primary)}.stat-value.stat-online{color:var(--success)}.stat-label{font-size:13px;color:var(--text-muted);margin-top:4px}.card{background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:20px;overflow:hidden}.card-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}.card-header h2{font-size:16px;font-weight:600}.fleet-header-left{display:flex;align-items:center;gap:12px}.card-body{padding:20px}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--radius);border:1px solid var(--border);background:var(--card-bg);color:var(--text);font-weight:500;font-size:13px;transition:all .15s}.btn:hover{background:#f0f2f5}.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary)}.btn-primary:hover{background:var(--primary-dark)}.btn-danger{background:var(--danger);color:#fff;border-color:var(--danger)}.btn-danger:hover{background:#c0392b}.btn-sm{padding:5px 10px;font-size:12px}.btn-block{display:block;width:100%;justify-content:center}.btn-group{display:flex;gap:8px}.btn-preparing,.btn-preparing:disabled{position:relative;overflow:hidden;opacity:1;cursor:wait}.btn-preparing:before{content:"";width:12px;height:12px;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;animation:btn-spin .8s linear infinite}.btn-preparing:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(100deg,transparent 0%,rgba(255,255,255,.28) 45%,transparent 70%);transform:translate(-100%);animation:btn-shimmer 1.4s ease-in-out infinite}@keyframes btn-spin{to{transform:rotate(360deg)}}@keyframes btn-shimmer{to{transform:translate(100%)}}.form-field{margin-bottom:16px}.form-field label{display:block;font-size:13px;font-weight:500;margin-bottom:6px;color:var(--text)}.form-field input,.form-field textarea,.form-field select{width:100%;padding:8px 12px;border:1px solid var(--border);border-radius:var(--radius);background:var(--card-bg);color:var(--text);transition:border-color .15s}.form-field input:focus,.form-field textarea:focus,.form-field select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px #2c95d626}.form-field textarea{font-family:Menlo,Monaco,Courier New,monospace;font-size:12px;resize:vertical}.ssh-key-form{margin-top:18px;max-width:760px}.cli-example-card{margin-top:18px;padding:16px;border:1px solid var(--border);border-radius:var(--radius);background:#f6f8fa}.cli-example-card h3{margin:0 0 8px;font-size:14px}.cli-example-card h3:not(:first-child){margin-top:16px}.cli-example-card pre{overflow-x:auto;margin:0;padding:12px;border-radius:8px;background:#0b1220;color:#dce7f7;font-size:12px}.table{width:100%;border-collapse:collapse}.table th{text-align:left;padding:10px 20px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);border-bottom:2px solid var(--border);background:#f8f9fb}.table td{padding:10px 20px;border-bottom:1px solid var(--border);font-size:13px}.table tr:hover td{background:#f8f9fb}.text-muted{color:var(--text-muted)}.text-sm{font-size:12px}.text-success{color:var(--success)}.text-danger{color:var(--danger)}.empty-state{padding:40px 20px;text-align:center;color:var(--text-muted)}.empty-state p{margin-bottom:12px;font-size:15px}.badge{display:inline-block;padding:2px 8px;border-radius:12px;font-size:11px;font-weight:600}.badge-success{background:#e8f5e9;color:var(--success)}.badge-danger{background:#fde8e8;color:var(--danger)}.badge-warning{background:#fff3e0;color:var(--warning)}.tab-bar{display:flex;border-bottom:2px solid var(--border);margin-bottom:20px}.tab-item{padding:10px 20px;border:none;background:none;font-size:14px;font-weight:500;color:var(--text-muted);border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .15s}.tab-item:hover{color:var(--text)}.tab-item.active{color:var(--primary);border-bottom-color:var(--primary)}.entity-search{display:flex;gap:10px;margin-bottom:10px}.entity-search input{flex:1;min-width:0;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius);background:var(--card-bg);color:var(--text);font-family:Menlo,Monaco,Courier New,monospace;font-size:13px}.entity-search input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px #2c95d626}.entity-summary{margin-bottom:14px}.variables-toolbar select,.variables-toolbar input,.config-value-input{min-width:160px;padding:8px 10px;border:1px solid var(--border);border-radius:var(--radius);background:var(--card-bg);color:var(--text)}.config-table td:first-child{min-width:280px}.config-table small{display:block;margin-top:4px;max-width:520px;line-height:1.35}.config-value-input{width:min(520px,100%);font-family:Menlo,Monaco,Courier New,monospace;font-size:12px}.config-actions{display:flex;gap:8px;flex-wrap:wrap}.diff-row.diff-added{background:#d9fbe1}.diff-row.diff-changed{background:#fff1c2}.diff-row.diff-deleted{background:#ffebe9;color:#57606a;text-decoration:line-through}.diff-old{background:#ffebe9;color:#a40e26;text-decoration:line-through}.diff-arrow{display:inline-block;margin:0 10px;color:var(--text-muted);text-decoration:none}.diff-actions{position:sticky;bottom:0;display:flex;justify-content:flex-end;gap:12px;margin:18px -20px -20px;padding:16px 20px;border-top:1px solid var(--border);background:#f6f8faf5;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.scope-pill{display:inline-block;padding:5px 9px;border-radius:6px;color:#fff;font-size:12px;font-weight:700}.scope-all{background:#d8b84f}.scope-service{background:#b83f63}.query-bar{display:flex;align-items:flex-start;gap:10px;margin-bottom:18px}.query-input-wrap{position:relative;flex:1;min-width:0}.query-icon{position:absolute;left:13px;top:50%;transform:translateY(-50%);color:var(--text-muted);font-size:20px;line-height:1;pointer-events:none}.query-input-wrap input{width:100%;padding:12px 14px 12px 42px;border:1px solid var(--border);border-radius:10px;background:var(--card-bg);color:var(--text);font-size:15px;box-shadow:var(--shadow)}.query-input-wrap input:focus{outline:none;border-color:#0969da;box-shadow:0 0 0 2px #0969da38,var(--shadow)}.query-highlight{position:absolute;top:0;right:0;bottom:0;left:0;padding:12px 14px 12px 42px;color:var(--text);font-size:15px;line-height:1.45;white-space:pre;pointer-events:none;overflow:hidden}.query-input-wrap.has-query input{background:transparent;color:transparent;caret-color:var(--text)}.query-value{color:#0969da;font-weight:600}.query-help{position:absolute;z-index:20;top:calc(100% + 8px);left:0;width:min(480px,100%);padding:14px 0;border:1px solid #d0d7de;border-radius:12px;background:var(--card-bg);box-shadow:0 12px 32px #1b1f242e}.query-help button{display:grid;grid-template-columns:14px 1fr;gap:12px;width:100%;padding:9px 18px;border:0;background:none;color:var(--text);text-align:left;cursor:pointer}.query-help button:hover{background:#f6f8fa}.query-help-back{border-bottom:1px solid var(--border)!important;margin-bottom:6px}.query-help strong,.query-help small{display:block}.query-help strong{font-size:14px}.query-help small{margin-top:3px;color:var(--text-muted);font-size:12px}.query-dot{width:10px;height:10px;margin-top:5px;border-radius:50%;background:var(--success)}.query-dot.danger{background:var(--danger)}.query-dot.warning{background:var(--warning)}.fleet-onboarding{padding:20px}.onboarding-step{margin-bottom:16px}.onboarding-step h3{font-size:15px;margin-bottom:8px}.onboarding-step pre{background:#f5f6f8;padding:12px;border-radius:var(--radius);font-size:12px;overflow-x:auto;border:1px solid var(--border)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:100}.modal{background:var(--card-bg);border-radius:12px;padding:24px;width:100%;max-width:480px;box-shadow:0 8px 32px #0003}.modal h2{font-size:18px;margin-bottom:16px}.variable-row{display:flex;align-items:center;gap:8px;padding:10px 20px;border-bottom:1px solid var(--border)}.variable-row .var-name{font-family:monospace;font-size:13px;font-weight:500;min-width:160px}.variable-row .var-value{flex:1;color:var(--text-muted);font-size:13px;word-break:break-all}.flex-row{display:flex;align-items:center;gap:12px}.flex-between{display:flex;align-items:center;justify-content:space-between}.mt-1{margin-top:8px}.mt-2{margin-top:16px}.mt-3{margin-top:24px}.mb-1{margin-bottom:8px}.ml-2{margin-left:16px}@media (max-width: 640px){.query-bar{flex-wrap:wrap}.query-input-wrap{flex-basis:100%}.query-bar .btn{flex:1;justify-content:center}.query-help{width:100%}}/**
 * Copyright (c) 2014 The xterm.js authors. All rights reserved.
 * Copyright (c) 2012-2013, Christopher Jeffrey (MIT License)
 * https://github.com/chjj/term.js
 * @license MIT
 *
 * Permission is hereby granted, free of charge, to any person obtaining a copy
 * of this software and associated documentation files (the "Software"), to deal
 * in the Software without restriction, including without limitation the rights
 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
 * copies of the Software, and to permit persons to whom the Software is
 * furnished to do so, subject to the following conditions:
 *
 * The above copyright notice and this permission notice shall be included in
 * all copies or substantial portions of the Software.
 *
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
 * THE SOFTWARE.
 *
 * Originally forked from (with the author's permission):
 *   Fabrice Bellard's javascript vt100 for jslinux:
 *   http://bellard.org/jslinux/
 *   Copyright (c) 2011 Fabrice Bellard
 *   The original design remains. The terminal itself
 *   has been extended to include xterm CSI codes, among
 *   other features.
 */.xterm{cursor:text;position:relative;user-select:none;-ms-user-select:none;-webkit-user-select:none}.xterm.focus,.xterm:focus{outline:none}.xterm .xterm-helpers{position:absolute;top:0;z-index:5}.xterm .xterm-helper-textarea{padding:0;border:0;margin:0;position:absolute;opacity:0;left:-9999em;top:0;width:0;height:0;z-index:-5;white-space:nowrap;overflow:hidden;resize:none}.xterm .composition-view{background:#000;color:#fff;display:none;position:absolute;white-space:nowrap;z-index:1}.xterm .composition-view.active{display:block}.xterm .xterm-viewport{background-color:#000;overflow-y:scroll;cursor:default;position:absolute;right:0;left:0;top:0;bottom:0}.xterm .xterm-screen{position:relative}.xterm .xterm-screen canvas{position:absolute;left:0;top:0}.xterm .xterm-scroll-area{visibility:hidden}.xterm-char-measure-element{display:inline-block;visibility:hidden;position:absolute;top:0;left:-9999em;line-height:normal}.xterm.enable-mouse-events{cursor:default}.xterm.xterm-cursor-pointer,.xterm .xterm-cursor-pointer{cursor:pointer}.xterm.column-select.focus{cursor:crosshair}.xterm .xterm-accessibility,.xterm .xterm-message{position:absolute;left:0;top:0;bottom:0;right:0;z-index:10;color:transparent;pointer-events:none}.xterm .live-region{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}.xterm-dim{opacity:1!important}.xterm-underline-1{text-decoration:underline}.xterm-underline-2{text-decoration:double underline}.xterm-underline-3{text-decoration:wavy underline}.xterm-underline-4{text-decoration:dotted underline}.xterm-underline-5{text-decoration:dashed underline}.xterm-overline{text-decoration:overline}.xterm-overline.xterm-underline-1{text-decoration:overline underline}.xterm-overline.xterm-underline-2{text-decoration:overline double underline}.xterm-overline.xterm-underline-3{text-decoration:overline wavy underline}.xterm-overline.xterm-underline-4{text-decoration:overline dotted underline}.xterm-overline.xterm-underline-5{text-decoration:overline dashed underline}.xterm-strikethrough{text-decoration:line-through}.xterm-screen .xterm-decoration-container .xterm-decoration{z-index:6;position:absolute}.xterm-screen .xterm-decoration-container .xterm-decoration.xterm-decoration-top-layer{z-index:7}.xterm-decoration-overview-ruler{z-index:8;position:absolute;top:0;right:0;pointer-events:none}.xterm-decoration-top{z-index:2;position:relative}.device-dashboard{width:100%;margin:0 auto}.device-hero{display:flex;justify-content:space-between;gap:20px;align-items:flex-start;margin-bottom:18px}.device-hero h1{margin-top:6px;font-size:28px;letter-spacing:-.02em}.editable-title{cursor:text;width:fit-content;max-width:100%}.editable-title:hover{color:var(--primary)}.editable-title-input{width:min(520px,100%);margin-top:6px;border:1px solid var(--border);border-radius:10px;background:var(--card-bg);color:var(--text);font-size:28px;font-weight:700;letter-spacing:-.02em;padding:5px 8px}.editable-title-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px #2c95d626}.device-hero p{color:var(--text-muted);font-family:Menlo,Monaco,Courier New,monospace;font-size:12px;margin-top:4px;word-break:break-all}.device-hero-actions{display:flex;align-items:center;justify-content:flex-start;gap:8px;flex-wrap:wrap;margin-top:10px}.device-grid{display:grid;grid-template-columns:minmax(520px,.92fr) minmax(560px,1.08fr);grid-template-areas:"overview metrics" "services logs" "services terminal";column-gap:20px;row-gap:16px}.panel{background:var(--card-bg);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow);overflow:hidden}.danger-zone{border-top:1px solid var(--border);background:#fff8f8}.panel-title{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:14px 16px;border-bottom:1px solid var(--border)}.panel-title h2{font-size:15px;font-weight:700}.panel-title span{color:var(--text-muted);font-size:12px}.overview-panel{grid-area:overview}.metrics-panel{grid-area:metrics}.services-panel{grid-area:services}.logs-panel{grid-area:logs}.settings-panel{grid-area:settings}.terminal-panel{grid-area:terminal}.metrics-panel,.logs-panel,.terminal-panel{border-left:3px solid #d7e0ea}.overview-split{display:grid;grid-template-columns:1fr 1fr;gap:12px;padding:16px 16px 0}.compact-field{margin-bottom:0}.responsive-row input,.responsive-row select{min-width:0}.overview-split .compact-field input{flex:0 1 360px;max-width:360px}.overview-split .compact-field select{flex:0 1 280px;max-width:280px}.kv-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;padding:16px}.kv-grid div,.metric-cards div{border:1px solid var(--border);border-radius:12px;padding:10px;background:#f8fafc;min-width:0}.kv-grid span,.metric-cards span{display:block;color:var(--text-muted);font-size:11px;text-transform:uppercase;letter-spacing:.04em;margin-bottom:5px}.kv-grid strong,.metric-cards strong{display:block;font-size:13px;word-break:break-word}.ip-card strong{display:flex;flex-direction:column;align-items:flex-start;gap:6px}.copy-chip{display:inline-flex;align-items:center;gap:8px;border:none;border-radius:5px;background:#fde8ec;color:#9f1239;padding:3px 6px;font-family:Menlo,Monaco,Courier New,monospace;font-size:12px}.copy-chip span{opacity:0;color:#214766;text-transform:none;letter-spacing:0;margin:0}.copy-chip:hover span{opacity:1}.release-row{display:grid;grid-template-columns:120px 1fr;align-items:center;gap:12px;padding:0 16px 16px}.release-row label{color:var(--text-muted);font-size:12px;font-weight:600}.release-row select,.terminal-add select,.var-add-row input{padding:8px 10px;border:1px solid var(--border);border-radius:8px;background:var(--card-bg);color:var(--text)}.metric-stack{padding:16px}.metric-line{display:flex;justify-content:space-between;font-size:13px;margin-bottom:6px}.metric-bar{height:9px;background:#e8edf4;border-radius:999px;overflow:hidden;margin-bottom:14px}.metric-bar div{height:100%;background:linear-gradient(90deg,#2c95d6,#67e8f9);border-radius:inherit;transition:width .2s}.metric-cards{display:grid;gap:8px;padding:0 16px 16px}.service-list{display:grid}.service-row{display:flex;justify-content:space-between;align-items:center;gap:12px;width:100%;padding:12px 16px;border:none;border-bottom:1px solid var(--border);background:transparent;text-align:left}.service-row:hover{background:#f8fafc}.service-row span:first-child{min-width:0}.service-row strong,.service-row small{display:block}.service-main{display:flex;align-items:center;gap:10px;flex-wrap:nowrap;flex:1 1 auto;min-width:0}.service-identity{display:inline-flex;align-items:center;gap:8px;flex:1 1 180px;min-width:0}.service-identity small{display:inline-block}.service-release-flow{display:flex;align-items:center;gap:7px;flex:0 0 auto;flex-wrap:nowrap;font-size:12px;white-space:nowrap}.service-release-flow a{color:#1d6fa8;font-weight:700}.release-arrow{color:#9f1239;font-weight:900}.service-progress{position:relative;display:inline-flex!important;width:fit-content;min-width:110px;overflow:hidden;border-radius:999px;background:#e8edf4;color:#214766;font-size:11px;font-weight:800;padding:3px 9px;white-space:nowrap}.service-progress i{position:absolute;inset:0 auto 0 0;background:linear-gradient(90deg,#2c95d659,#67e8f959)}.service-progress{isolation:isolate}.service-progress span{position:relative}.service-pill{display:inline-block!important;width:fit-content;border-radius:3px;padding:6px 8px;color:#fff;font-size:12px;line-height:1;margin-bottom:5px}.service-row small{color:var(--text-muted);font-family:Menlo,Monaco,Courier New,monospace;font-size:11px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:150px}.service-actions{flex:0 0 auto;display:flex;align-items:center;gap:8px;flex-wrap:nowrap;justify-content:flex-end}.icon-action{border:1px solid #c7d6e6;border-radius:6px;background:#fff;color:#214766;padding:4px 7px;font-size:11px;font-weight:700}.icon-action:disabled{opacity:.5;cursor:wait}.compact-empty{padding:24px 16px}.log-window{margin:16px;min-height:210px;max-height:360px;overflow-y:auto;border-radius:12px;background:#07111f;color:#b7c8de;font-family:Menlo,Monaco,Courier New,monospace;font-size:12px;line-height:1.6;padding:14px}.log-window p+p{margin-top:10px}.log-line{display:flex;align-items:baseline;gap:8px;white-space:pre-wrap;word-break:break-word}.log-time{flex:0 0 auto;color:#7891ad;font-size:11px}.log-service{flex:0 0 auto;border-radius:4px;color:#fff;font-family:Inter,system-ui,sans-serif;font-size:11px;font-weight:800;line-height:1;padding:3px 6px}.log-window code{color:#67e8f9}.var-add-row{display:grid;grid-template-columns:minmax(90px,.8fr) minmax(120px,1.2fr) auto;gap:8px;padding:16px}.compact-table{display:grid;border-top:1px solid var(--border);max-height:220px;overflow-y:auto}.compact-table>p{padding:14px 16px}.compact-var-row{display:grid;grid-template-columns:minmax(120px,.8fr) minmax(120px,1fr) auto;align-items:center;gap:8px;padding:9px 16px;border-bottom:1px solid var(--border)}.compact-var-row code{font-size:12px;word-break:break-word}.compact-var-row span{color:var(--text-muted);font-size:12px;word-break:break-all}.compact-var-row em{color:var(--text-muted);font-size:11px;font-style:normal}.muted-row{background:#fbfcfe}.terminal-title{align-items:flex-start;justify-content:flex-start}.terminal-title h2{margin-bottom:2px}.terminal-add{display:flex;gap:8px;align-items:center}.terminal-title>.terminal-add:first-child{order:-1}.terminal-title>div:nth-child(2){flex:1}.terminal-vscode-btn{width:38px;height:34px;border:1px solid rgba(35,141,214,.45);border-radius:9px;background:#07111f;box-shadow:0 8px 18px #007acc38;display:inline-flex;align-items:center;justify-content:center}.terminal-vscode-btn:disabled{cursor:not-allowed;filter:grayscale(.7);opacity:.55}.terminal-vscode-btn img{width:23px;height:23px;display:block}.terminal-tabs{display:flex;gap:6px;padding:10px 12px 0;background:#07111f;overflow-x:auto}.terminal-tabs button{display:inline-flex;align-items:center;gap:8px;border:1px solid rgba(255,255,255,.12);border-top:3px solid rgba(255,255,255,.12);border-bottom:none;border-radius:9px 9px 0 0;background:#122036;color:#a9bdd6;padding:7px 10px;font-size:12px}.terminal-tabs button i{width:8px;height:8px;border-radius:50%;display:inline-block}.terminal-tabs button.active{background:#08111f;color:#fff}.terminal-tabs button span{color:#94a3b8;font-weight:700}.terminal-alert{margin:0;border-radius:0}.terminal-empty{min-height:360px;display:flex;align-items:center;justify-content:center;padding:24px;background:#08111f;color:#8fa6c1;font-size:13px}.terminal-surface{min-height:360px;padding:8px;background:#08111f}.settings-page{padding:0 28px}.settings-row{display:grid;grid-template-columns:minmax(220px,.45fr) minmax(320px,1fr);gap:28px;align-items:center;padding:28px 0;border-bottom:1px dashed #cdd8e5}.settings-row:last-child{border-bottom:none}.settings-row h2{font-size:16px;font-weight:500;color:#173552}.settings-row p{margin-top:8px;color:var(--text-muted);font-size:12px}.settings-row input,.settings-row select{width:100%;padding:10px 12px;border:1px solid #9dc1e4;border-radius:4px;background:#fff;color:var(--text)}.readonly-row strong{color:var(--text-muted);font-size:13px}.variables-page{overflow-x:auto}.variables-toolbar{display:flex;align-items:center;gap:12px;padding:16px;border-bottom:1px solid var(--border)}.variables-toolbar input{min-width:180px;flex:1;padding:9px 10px;border:1px solid var(--border);border-radius:8px}.variables-toolbar h2{font-size:16px}.inheritance-note{padding:10px 16px;border-bottom:1px solid var(--border);background:#f8fafc;color:var(--text-muted);font-size:12px}.variables-table th{background:#dce7f1}.variables-table td{height:45px}.variables-table code{padding:3px 6px;border-radius:4px;background:#f4f7fb;color:#173552;word-break:break-all}.release-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(380px,.65fr);gap:16px}.release-compose-panel pre{margin:0;min-height:520px;max-height:780px;overflow:auto;padding:18px;background:#2f2f2f;color:#f5f5f5;font-family:Menlo,Monaco,Courier New,monospace;font-size:13px;line-height:1.5;white-space:pre-wrap}@media (max-width: 1180px){.device-grid{grid-template-columns:1fr;grid-template-areas:"overview" "metrics" "services" "logs" "terminal"}.metrics-panel,.logs-panel,.terminal-panel{border-left-width:1px}.release-grid{grid-template-columns:1fr}}@media (max-width: 760px){.device-hero,.device-hero-actions,.terminal-title,.terminal-add{display:block}.device-hero-actions>*,.terminal-add>*{margin-top:8px;margin-right:8px}.device-grid{grid-template-columns:1fr;grid-template-areas:"overview" "metrics" "services" "logs" "settings" "terminal"}.overview-split,.kv-grid,.var-add-row,.compact-var-row,.release-row,.settings-row{grid-template-columns:1fr}.variables-toolbar{align-items:stretch;flex-direction:column}.responsive-row{align-items:flex-start;flex-direction:row;flex-wrap:wrap;gap:8px}.overview-split{gap:10px;padding:12px 12px 0}.overview-split .compact-field input,.overview-split .compact-field select{flex:0 1 210px;max-width:min(210px,100%);width:auto;padding:6px 9px;font-size:13px}.overview-split .compact-field .btn-sm{padding:6px 9px;font-size:12px}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--primary: #2c95d6;--primary-dark: #2278ad;--bg: #f5f7fa;--sidebar-bg: #1a2332;--sidebar-text: #a4b7cd;--sidebar-active: #2c95d6;--card-bg: #fff;--text: #2e3b4e;--text-muted: #7e8ea2;--border: #e1e5eb;--success: #4caf50;--danger: #e74c3c;--warning: #f39c12;--radius: 8px;--shadow: 0 1px 3px rgba(0,0,0,.1)}html,body,#root{height:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px;color:var(--text);background:var(--bg);line-height:1.5}a{color:var(--primary);text-decoration:none}a:hover{text-decoration:underline}button{cursor:pointer;font-family:inherit;font-size:inherit}input,select{font-family:inherit;font-size:inherit}.page-loading{display:flex;align-items:center;justify-content:center;height:100vh;font-size:18px;color:var(--text-muted)}
