/* node_modules/@xterm/xterm/css/xterm.css */
.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:not(.debug),
.xterm .xterm-message {
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  right: 0;
  z-index: 10;
  color: transparent;
  pointer-events: none;
}
.xterm .xterm-accessibility-tree:not(.debug) *::selection {
  color: transparent;
}
.xterm .xterm-accessibility-tree {
  user-select: text;
  white-space: pre;
}
.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;
}

/* web/src/app.css */
:root {
  color-scheme: dark;
}
* {
  box-sizing: border-box;
}
html,
body {
  margin: 0;
  height: 100%;
  background: #0b0e14;
  color: #bfbdb6;
  font:
    13px/1.4 -apple-system,
    BlinkMacSystemFont,
    Menlo,
    monospace;
}
body {
  display: grid;
  grid-template-rows: auto auto 1fr auto;
  height: 100vh;
}
#bar {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 6px 10px;
  background: #11151c;
  border-bottom: 1px solid #1c2330;
}
#brand {
  font-weight: 600;
  color: #e6e1cf;
}
.spacer {
  flex: 1;
}
.status {
  padding: 2px 8px;
  border-radius: 10px;
  background: #222;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.status.ready {
  background: #1d3b2a;
  color: #7fd1a3;
}
.status.connecting,
.status.reconnecting {
  background: #3b341d;
  color: #d1c07f;
}
.status.dead {
  background: #3b1d1d;
  color: #d18f8f;
}
#sizeinfo {
  font-size: 11px;
  color: #7c8597;
}
.ctrlgrp button,
#accessory button {
  background: #1c2330;
  color: #bfbdb6;
  border: 1px solid #2a3344;
  border-radius: 6px;
  padding: 3px 8px;
  cursor: pointer;
  font: inherit;
}
.ctrlgrp button:hover {
  background: #243044;
}
#accessory button.on {
  background: #2dd4a0;
  color: #04221a;
}
#tabbar {
  display: flex;
  gap: 4px;
  padding: 4px 8px 0;
  background: #0d1118;
  border-bottom: 1px solid #1c2330;
  overflow-x: auto;
}
.tab {
  display: flex;
  align-items: center;
  gap: 6px;
  background: #141a24;
  color: #9aa3b2;
  border: 1px solid #1c2330;
  border-bottom: none;
  border-radius: 6px 6px 0 0;
  padding: 5px 10px;
  cursor: pointer;
  white-space: nowrap;
  font: inherit;
}
.tab.active {
  background: #0b0e14;
  color: #e6e1cf;
}
.tab.ended {
  opacity: 0.55;
}
.dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
}
.dot.green {
  background: #7fd1a3;
}
.dot.red {
  background: #d18f8f;
}
.badge {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #d1c07f;
}
.tab .kill {
  margin-left: 4px;
  opacity: 0.6;
  font-weight: 700;
}
.tab .kill:hover {
  opacity: 1;
  color: #d18f8f;
}
#spawn-btn {
  background: #1c2330;
  color: #e6e1cf;
  border: 1px solid #2a3344;
  border-radius: 6px;
  padding: 2px 9px;
  cursor: pointer;
  font-size: 15px;
  line-height: 1;
}
#spawn-btn:hover {
  background: #243044;
}
#spawn-menu {
  position: fixed;
  z-index: 50;
  background: #141a24;
  border: 1px solid #2a3344;
  border-radius: 8px;
  padding: 4px;
  min-width: 200px;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.4);
}
#spawn-menu .mi {
  padding: 7px 10px;
  border-radius: 5px;
  cursor: pointer;
  white-space: nowrap;
}
#spawn-menu .mi:hover {
  background: #243044;
}
#spawn-menu .mi.muted {
  color: #7c8597;
  cursor: default;
}
#termhost {
  position: relative;
  overflow: hidden;
  background: #0b0e14;
}
.term-wrap {
  position: absolute;
  inset: 0;
  overflow: hidden;
  padding: 2px;
}
.landing {
  padding: 40px;
  max-width: 560px;
  margin: 0 auto;
}
.landing h1 {
  color: #e6e1cf;
}
.landing .warn {
  color: #d1c07f;
  border: 1px solid #3b341d;
  padding: 10px;
  border-radius: 6px;
}
#accessory {
  display: none;
  gap: 6px;
  padding: 6px;
  background: #11151c;
  border-top: 1px solid #1c2330;
  overflow-x: auto;
}
@media (pointer: coarse), (max-width: 700px) {
  #accessory {
    display: flex;
  }
}
/*! Bundled license information:

@xterm/xterm/css/xterm.css:
  (**
   * 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.
   *)
*/
/*# sourceMappingURL=app.css.map */
