/**
 * 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.
 */

/**
 *  Default styles for xterm.js
 */

.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;
    /**
     * The z-index of the helpers must be higher than the canvases in order for
     * IMEs to appear on top.
     */
    z-index: 5;
}

.xterm .xterm-helper-textarea {
    padding: 0;
    border: 0;
    margin: 0;
    /* Move textarea out of the screen to the far left, so that the cursor is not visible */
    position: absolute;
    opacity: 0;
    left: -9999em;
    top: 0;
    width: 0;
    height: 0;
    z-index: -5;
    /** Prevent wrapping so the IME appears against the textarea at the correct position */
    white-space: nowrap;
    overflow: hidden;
    resize: none;
}

.xterm .composition-view {
    /* TODO: Composition position got messed up somewhere */
    background: #000;
    color: #FFF;
    display: none;
    position: absolute;
    white-space: nowrap;
    z-index: 1;
}

.xterm .composition-view.active {
    display: block;
}

.xterm .xterm-viewport {
    /* On OS X this is required in order for the scroll bar to appear fully opaque */
    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 {
    /* When mouse events are enabled (eg. tmux), revert to the standard pointer cursor */
    cursor: default;
}

.xterm.xterm-cursor-pointer,
.xterm .xterm-cursor-pointer {
    cursor: pointer;
}

.xterm.column-select.focus {
    /* Column selection mode */
    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 {
    /* Dim should not apply to background, so the opacity of the foreground color is applied
     * explicitly in the generated class and reset to 1 here */
    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;
}
:root {
  --bg: #0d1117;
  --panel: #11161e;
  --panel-2: #161c26;
  --line: #232b38;
  --text: #d7dee8;
  --muted: #7d8aa0;
  --accent: #4c8dff;
  --accent-dim: #2b3b5c;
  --green: #3fb950;
  --amber: #d2a24a;
  --red: #f06d6d;
  --font-mono: ui-monospace, "SF Mono", "JetBrains Mono", Menlo, monospace;
}

* { box-sizing: border-box; }

html, body, #root { height: 100%; margin: 0; }

body {
  background: var(--bg);
  color: var(--text);
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  font-size: 13px;
  -webkit-font-smoothing: antialiased;
}

.app { display: flex; flex-direction: column; height: 100%; }

/* Topbar */
.topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 16px;
  border-bottom: 1px solid var(--line);
  background: var(--panel);
  -webkit-app-region: drag;
}
.brand { font-weight: 600; letter-spacing: 0.2px; display: flex; align-items: center; gap: 8px; }
.brand .dot { width: 9px; height: 9px; border-radius: 50%; background: var(--accent); box-shadow: 0 0 10px var(--accent); }
.brand .tag {
  font-size: 10px; color: var(--muted); border: 1px solid var(--line);
  border-radius: 5px; padding: 1px 6px; font-weight: 500;
}
.topright { display: flex; align-items: center; gap: 12px; -webkit-app-region: no-drag; }
.modelsel { display: flex; align-items: center; gap: 7px; font-size: 11px; color: var(--muted); text-transform: uppercase; letter-spacing: 0.5px; }
.statuspill {
  font-family: var(--font-mono); font-size: 11px; color: var(--muted);
  border: 1px solid var(--line); border-radius: 20px; padding: 4px 12px;
  max-width: 280px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.statuspill.busy { color: var(--accent); border-color: var(--accent-dim); }

/* Server-modus-kontroll */
.server-ctl { display: flex; align-items: center; gap: 6px; position: relative; }
/* Login-lenker (mobil): popover under «Server»-knappen med kopierbare token-i-URL-lenker */
.srv-links { position: absolute; top: 100%; right: 0; margin-top: 6px; z-index: 30; width: 340px; max-width: 80vw;
  background: var(--panel-2); border: 1px solid var(--accent-dim); border-radius: 10px; padding: 10px; display: flex; flex-direction: column; gap: 6px; box-shadow: 0 8px 24px rgba(0,0,0,0.4); }
.srv-links-hint { color: var(--muted); font-size: 11px; line-height: 1.4; }
.srv-links-empty { color: var(--red); font-size: 11px; line-height: 1.4; }
.srv-link { display: flex; align-items: center; gap: 8px; background: var(--bg); border: 1px solid var(--line); border-radius: 7px; padding: 7px 9px; cursor: pointer; text-align: left; }
.srv-link:hover { border-color: var(--accent); }
.srv-link-label { color: var(--accent); font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.4px; white-space: nowrap; }
.srv-link-url { color: var(--text); font-family: var(--font-mono); font-size: 11px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; flex: 1; }
.srv-link-copy { color: var(--muted); font-size: 10px; white-space: nowrap; }
.srvbtn {
  display: flex; align-items: center; gap: 6px;
  background: transparent; color: var(--muted); border: 1px solid var(--line);
  border-radius: 20px; padding: 4px 12px; font-size: 11px; font-weight: 500;
}
.srvbtn .srvdot { width: 7px; height: 7px; border-radius: 50%; background: var(--muted); }
.srvbtn.on { color: var(--green); border-color: #2f6b39; }
.srvbtn.on .srvdot { background: var(--green); box-shadow: 0 0 8px var(--green); }
.srverr { color: var(--red); font-size: 10px; max-width: 160px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* Form-elementer */
select, input {
  font: inherit;
  background: var(--bg);
  color: var(--text);
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 5px 8px;
}
select { cursor: pointer; }
select:disabled { opacity: 0.5; }

/* Fane-rad (én fane per arbeidsflate, farget per prosjekt) */
.tabbar {
  display: flex; align-items: flex-end; gap: 3px;
  padding: 6px 10px 0; background: var(--panel);
  border-bottom: 1px solid var(--line); overflow-x: auto;
}
.tabchip {
  display: flex; align-items: center; gap: 7px;
  padding: 6px 9px; border: 1px solid var(--line); border-bottom: none;
  border-radius: 7px 7px 0 0; background: var(--panel-2); color: var(--muted);
  cursor: pointer; max-width: 210px; flex: none;
}
.tabchip:hover { color: var(--text); }
.tabchip.active { background: var(--bg); color: var(--text); box-shadow: inset 0 2px 0 var(--pc); }
.tabdot { width: 9px; height: 9px; border-radius: 50%; background: var(--pc); flex: none; box-shadow: 0 0 6px var(--pc); }
.tabtitle { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; font-size: 12px; max-width: 150px; }
.tabrename { font-size: 12px; padding: 1px 5px; width: 140px; }
.tabbusy {
  width: 8px; height: 8px; border-radius: 50%; flex: none;
  border: 1.5px solid var(--accent); border-top-color: transparent; animation: tabspin 0.7s linear infinite;
}
@keyframes tabspin { to { transform: rotate(360deg); } }
.tabclose { background: transparent; border: none; color: var(--muted); padding: 0 1px; font-size: 15px; line-height: 1; border-radius: 4px; }
.tabclose:hover { color: var(--red); }
.tabadd { background: transparent; border: 1px solid var(--line); color: var(--muted); border-radius: 6px; padding: 5px 11px; margin-left: 2px; flex: none; align-self: center; }
.tabadd:hover { color: var(--text); border-color: var(--accent-dim); }
.tabkind { color: var(--muted); font-size: 11px; flex: none; }

/* Terminal-fane (xterm) */
.xterm-host { flex: 1; min-height: 0; padding: 6px 4px 6px 8px; background: var(--bg); overflow: hidden; }
.xterm-host .xterm { height: 100%; }

/* Prosjektbar */
.projectbar {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 16px;
  background: var(--panel-2);
  border-bottom: 1px solid var(--line);
  font-size: 12px;
}
.pb-label { color: var(--muted); text-transform: uppercase; font-size: 10px; letter-spacing: 0.6px; }
.pb-current { font-weight: 600; color: var(--accent); }
.pb-select { min-width: 220px; }
.pb-path { color: var(--muted); font-family: var(--font-mono); font-size: 10.5px; margin-left: auto; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* Mappevelger-modal (web-modus — ingen native dialog) */
.fp-overlay { position: fixed; inset: 0; background: rgba(0, 0, 0, 0.55); display: flex; align-items: center; justify-content: center; z-index: 60; }
.fp { background: var(--panel); border: 1px solid var(--line); border-radius: 12px; width: 480px; max-width: 92vw; height: 70vh; max-height: 560px; display: flex; flex-direction: column; box-shadow: 0 12px 40px rgba(0, 0, 0, 0.5); }
.fp-head { display: flex; align-items: center; justify-content: space-between; padding: 12px 14px; border-bottom: 1px solid var(--line); font-weight: 600; }
.fp-path { display: flex; gap: 6px; padding: 10px 14px 0; }
.fp-path input { flex: 1; font-family: var(--font-mono); font-size: 12px; min-width: 0; }
.fp-err { color: var(--red); font-size: 12px; padding: 8px 14px 0; }
.fp-list { flex: 1; overflow-y: auto; padding: 8px; }
.fp-item { display: block; width: 100%; text-align: left; background: transparent; border: none; color: var(--text); padding: 6px 10px; border-radius: 6px; font-size: 13px; font-weight: 400; }
.fp-item:hover { background: var(--panel-2); filter: none; }
.fp-item.up { color: var(--muted); }
.fp-foot { display: flex; align-items: center; gap: 8px; padding: 10px 14px; border-top: 1px solid var(--line); }
.fp-cur { flex: 1; color: var(--muted); font-family: var(--font-mono); font-size: 11px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; direction: rtl; text-align: left; }

/* Tre kolonner */
.cols {
  display: grid;
  grid-template-columns: 280px 1fr 1fr;
  gap: 1px;
  background: var(--line);
  flex: 1;
  min-height: 0;
}
.panel { background: var(--panel); display: flex; flex-direction: column; min-height: 0; }
.panel-head {
  display: flex; align-items: center; justify-content: space-between; gap: 8px;
  padding: 9px 14px; font-size: 11px; text-transform: uppercase; letter-spacing: 0.6px;
  color: var(--muted); border-bottom: 1px solid var(--line); background: var(--panel-2);
  min-height: 36px;
}
.panel-head button { text-transform: none; letter-spacing: 0; }
.ph-title { flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* Gjøremål */
.tasklist { margin: 0; padding: 8px; overflow-y: auto; flex: 1; }
.task {
  display: flex; flex-direction: column; gap: 6px;
  padding: 9px 11px; border-radius: 8px; margin-bottom: 6px;
  border: 1px solid transparent; background: var(--panel-2);
}
.task.sub { margin-left: 16px; border-left: 2px solid var(--line); border-radius: 0 8px 8px 0; background: var(--panel); }
.task.in_progress { border-color: var(--accent-dim); }
.task.done { opacity: 0.6; }
.task-row { display: flex; align-items: baseline; gap: 8px; }
.task-status { font-family: var(--font-mono); font-size: 10.5px; color: var(--muted); white-space: nowrap; }
.task.in_progress .task-status { color: var(--accent); }
.task.done .task-status { color: var(--green); }
.task-title { font-size: 13px; flex: 1; word-break: break-word; }
.task.done .task-title { text-decoration: line-through; }

.ctx-toggle {
  background: transparent; color: var(--muted); border: none; padding: 0;
  font-size: 10.5px; cursor: pointer; white-space: nowrap;
}
.ctx-toggle:hover { color: var(--accent); }

.task-actions { display: flex; flex-wrap: wrap; gap: 4px; }
.task-actions button { padding: 3px 8px; font-size: 10.5px; }
.task-actions button.danger:hover { color: var(--red); border-color: var(--red); }

/* Resume-kontekst (kapsel) */
.ctx { display: flex; flex-direction: column; gap: 8px; padding: 8px 2px 2px; border-top: 1px dashed var(--line); }
.ctx-block { display: flex; flex-direction: column; gap: 4px; }
.ctx-label { color: var(--muted); text-transform: uppercase; font-size: 9px; letter-spacing: 0.6px; }
.ctx-notes { font-size: 11.5px; line-height: 1.45; color: var(--text); white-space: pre-wrap; }
.chips { display: flex; flex-wrap: wrap; gap: 4px; }
.chip {
  font-family: var(--font-mono); font-size: 10.5px; color: var(--text);
  background: var(--bg); border: 1px solid var(--line); border-radius: 5px; padding: 2px 6px; word-break: break-all;
}
.chip.mem { color: var(--amber); }
.ctx-meta { flex-direction: row; gap: 6px; flex-wrap: wrap; }

/* Oppgave-editor */
.task-editor {
  display: flex; flex-direction: column; gap: 7px;
  padding: 11px; border-radius: 8px; margin-bottom: 6px;
  background: var(--panel-2); border: 1px solid var(--accent-dim);
}
.te-head { font-size: 11px; text-transform: uppercase; letter-spacing: 0.6px; color: var(--accent); }
.te-input, .te-area { width: 100%; font-family: inherit; font-size: 12px; }
.te-area { resize: vertical; font-family: var(--font-mono); line-height: 1.5; }
.te-ctxtoggle { text-align: left; font-size: 11px; padding: 2px 0; }
.te-ctx { display: flex; flex-direction: column; gap: 6px; padding: 4px 0 2px; border-top: 1px dashed var(--line); }
.te-row { display: flex; gap: 6px; }
.te-row .te-input { flex: 1; }
.te-actions { display: flex; gap: 8px; margin-top: 2px; }
.te-actions button { padding: 6px 12px; font-size: 12px; }

.controls { padding: 12px; display: flex; flex-wrap: wrap; gap: 8px; border-top: 1px solid var(--line); }
button {
  font: inherit; cursor: pointer;
  background: var(--accent); color: #fff; border: none;
  border-radius: 7px; padding: 8px 14px; font-weight: 500;
}
button:hover { filter: brightness(1.08); }
button:disabled { opacity: 0.4; cursor: default; filter: none; }
button.ghost { background: transparent; color: var(--muted); border: 1px solid var(--line); }
button.sm { padding: 4px 10px; font-size: 11px; }

/* Chat / logg */
.chat.panel, .log.panel { overflow: hidden; }
.chat-head .sess { color: var(--green); font-family: var(--font-mono); font-size: 10px; margin-left: 8px; }
.log-body { flex: 1; overflow-y: auto; padding: 10px 14px; font-family: var(--font-mono); font-size: 12px; line-height: 1.55; }
.hint { color: var(--muted); font-style: italic; }
.ev { white-space: pre-wrap; word-break: break-word; padding: 1px 0; }
.ev.user {
  color: var(--text); background: var(--panel-2); border: 1px solid var(--line);
  border-radius: 8px; padding: 8px 11px; margin: 10px 0 6px; font-family: -apple-system, sans-serif;
}
.ev.user .ev-you {
  display: inline-block; color: var(--accent); font-size: 9px; text-transform: uppercase;
  letter-spacing: 0.6px; margin-right: 8px; vertical-align: 1px;
}
.ev.divider { color: var(--accent); margin: 12px 0 4px; font-weight: 600; }
.ev.text { color: var(--text); }
.ev.status { color: var(--muted); }
.ev.tool { color: var(--amber); }
.ev.file { color: var(--accent); }
.ev.error { color: var(--red); }
.ev.done { color: var(--green); font-weight: 600; }

/* Composer (chat-input nederst i midtkolonnen) */
.composer { border-top: 1px solid var(--line); padding: 10px 12px; background: var(--panel); display: flex; flex-direction: column; gap: 8px; }
.chat-input {
  width: 100%; resize: none; background: var(--bg); color: var(--text);
  border: 1px solid var(--line); border-radius: 8px; padding: 10px 12px;
  font-family: -apple-system, BlinkMacSystemFont, sans-serif; font-size: 13px; line-height: 1.5;
}
.chat-input:focus { outline: none; border-color: var(--accent-dim); }
.chat-input:disabled { opacity: 0.6; }
.composer-actions { display: flex; gap: 8px; align-items: center; }
.composer-actions button { padding: 7px 16px; }
.composer-meta { margin-left: auto; color: var(--muted); font-family: var(--font-mono); font-size: 10.5px; }

/* Slash-palett (over meldingsfeltet) */
.slashmenu {
  border: 1px solid var(--accent-dim); border-radius: 8px; background: var(--panel-2);
  overflow: hidden; box-shadow: 0 -4px 16px rgba(0, 0, 0, 0.3);
}
.slashitem { display: flex; align-items: baseline; gap: 10px; padding: 7px 11px; cursor: pointer; }
.slashitem.active { background: var(--accent-dim); }
.slashcmd { color: var(--accent); font-family: var(--font-mono); font-size: 12px; min-width: 72px; }
.slashitem.active .slashcmd { color: #fff; }
.slashdesc { color: var(--muted); font-size: 11.5px; }
.slashitem.active .slashdesc { color: var(--text); }

/* Modus-bryter (read-only ↔ workspace-write) */
.modebtn {
  background: transparent; border: 1px solid var(--line); color: var(--muted);
  border-radius: 20px; padding: 3px 11px; font-size: 11px; font-weight: 500; white-space: nowrap;
}
.modebtn:hover { color: var(--text); }
.modebtn.write {
  color: var(--amber); border-color: var(--amber);
  background: rgba(210, 162, 74, 0.12); font-weight: 600;
}
.modebtn.bypass {
  color: var(--red); border-color: var(--red);
  background: rgba(240, 109, 109, 0.14); font-weight: 600;
}
/* Tydelig markering etter tilgangsnivå */
.composer.write { border-top-color: var(--amber); box-shadow: inset 0 2px 0 var(--amber); }
.composer.write .chat-input { border-color: rgba(210, 162, 74, 0.4); }
.composer.bypass { border-top-color: var(--red); box-shadow: inset 0 2px 0 var(--red); }
.composer.bypass .chat-input { border-color: rgba(240, 109, 109, 0.45); }
.composer-actions button.debate { color: var(--accent); border-color: var(--accent-dim); }
.recipesel { font-size: 11px; padding: 4px 6px; }

/* Orkestrerings-kort (debatt → dommer), inline i samtalen */
.orch {
  margin: 12px 0; border: 1px solid var(--accent-dim); border-radius: 10px;
  background: var(--panel-2); overflow: hidden; font-family: -apple-system, sans-serif;
}
.orch-head {
  padding: 9px 12px; background: rgba(76, 141, 255, 0.1); color: var(--accent);
  font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.4px;
  border-bottom: 1px solid var(--line);
}
.orch-role { border-bottom: 1px solid var(--line); }
.orch-roletog {
  display: flex; align-items: center; gap: 9px; width: 100%; text-align: left;
  background: transparent; border: none; color: var(--text); padding: 8px 12px; font-size: 12.5px;
}
.orch-roletog:hover { background: var(--panel); }
.orch-rolename { flex: 1; }
.orch-expand { color: var(--muted); font-size: 11px; }
.orch-state { font-family: var(--font-mono); font-size: 12px; width: 14px; text-align: center; }
.orch-state.running { color: var(--accent); }
.orch-state.done { color: var(--green); }
.orch-state.failed, .orch-state.timeout { color: var(--red); }
.orch-state.pending { color: var(--muted); }
.orch-roletext {
  padding: 8px 14px 12px 35px; color: var(--muted); font-family: var(--font-mono);
  font-size: 11.5px; line-height: 1.55; white-space: pre-wrap; word-break: break-word;
  border-top: 1px dashed var(--line);
}
.orch-judge { background: rgba(63, 185, 80, 0.06); }
.orch-judge-head {
  display: flex; align-items: center; gap: 9px; padding: 9px 12px;
  color: var(--green); font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.4px;
}
.orch-judge-text {
  padding: 0 14px 12px 35px; color: var(--text); font-size: 13px; line-height: 1.55;
  white-space: pre-wrap; word-break: break-word;
}

/* Multi-agent-popover (åpnes fra «Flere: N ▾» i composeren) */
.mab-trigger.on { color: var(--accent); border-color: var(--accent-dim); }
.mab-pop {
  border: 1px solid var(--accent-dim); border-radius: 10px; background: var(--panel-2);
  padding: 10px 12px; display: flex; flex-direction: column; gap: 9px;
  box-shadow: 0 -4px 16px rgba(0, 0, 0, 0.3);
}
.mab-pop-row { display: flex; flex-wrap: wrap; align-items: center; gap: 8px; }
.mab-pop-label { color: var(--muted); font-size: 10px; text-transform: uppercase; letter-spacing: 0.5px; }
.mab-chips { display: flex; flex-wrap: wrap; gap: 3px; }
.mab-chip { background: var(--bg); border: 1px solid var(--line); color: var(--muted); border-radius: 20px; padding: 3px 9px; font-size: 10.5px; }
.mab-chip.on { background: var(--accent-dim); border-color: var(--accent); color: #fff; }
.mab-presets { display: flex; align-items: center; gap: 5px; }
.mab-master-sel { display: flex; align-items: center; gap: 5px; color: var(--muted); font-size: 10px; text-transform: uppercase; letter-spacing: 0.4px; margin-left: auto; }
.mab-master-sel select { font-size: 11px; padding: 3px 5px; }
.mab-pop-foot { display: flex; flex-wrap: wrap; align-items: center; gap: 8px; padding-top: 8px; border-top: 1px dashed var(--line); }
.mab-cost { color: var(--muted); font-size: 11px; margin-right: auto; }
/* Visnings-bryter «Se alle / Syntese» (segmentert) + primær «Kjør med flere» */
.mab-viewtoggle { display: inline-flex; border: 1px solid var(--line); border-radius: 7px; overflow: hidden; }
.mab-viewtoggle button { background: transparent; color: var(--muted); border: none; border-radius: 0; padding: 5px 11px; font-size: 11px; font-weight: 500; }
.mab-viewtoggle button + button { border-left: 1px solid var(--line); }
.mab-viewtoggle button.on { background: var(--accent-dim); color: #fff; }
.mab-run { font-size: 12px; padding: 7px 14px; }

/* Multi-agent-kort (kringkast → kolonner / debatt-konklusjon) */
.mab { margin: 12px 0; border: 1px solid var(--accent-dim); border-radius: 10px; background: var(--panel-2); overflow: hidden; font-family: -apple-system, sans-serif; }
.mab-head { padding: 9px 12px; background: rgba(76, 141, 255, 0.1); color: var(--accent); font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.4px; border-bottom: 1px solid var(--line); }
.mab-toggle { padding: 7px 12px; font-size: 11px; }
.mab-cols { display: flex; gap: 1px; background: var(--line); border-top: 1px solid var(--line); overflow-x: auto; }
.mab-col { flex: 1 1 0; min-width: 170px; background: var(--panel-2); padding: 9px 11px; display: flex; flex-direction: column; gap: 6px; }
.mab-col-head { font-size: 11.5px; font-weight: 600; color: var(--text); display: flex; align-items: center; gap: 6px; }
.mab-col-text { font-size: 12px; line-height: 1.5; color: var(--muted); white-space: pre-wrap; word-break: break-word; flex: 1; }
.mab-col-actions { display: flex; flex-wrap: wrap; gap: 5px; align-self: flex-start; }
.mab-continue { color: var(--accent); border-color: var(--accent-dim); }
.mab-masterbtn { margin: 10px 12px; }
.mab-master-actions { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 8px; }
/* Fold-in = den grønne «commit til master»-handlingen (matcher fold-gate-temaet). Solid grønn med
   mørk tekst → høy kontrast (tidligere: grønn tekst på blå primary-bakgrunn = uleselig). */
.mab-fold { background: var(--green); color: var(--bg); border: none; font-weight: 600; }

/* Fold-gate: godkjennings-port (rediger-før-commit) over composer */
.fold-gate { margin: 0 12px 8px; padding: 10px; border: 1px solid rgba(63, 185, 80, 0.4); border-radius: 8px; background: rgba(63, 185, 80, 0.06); display: flex; flex-direction: column; gap: 8px; }
.fold-gate-head { display: flex; justify-content: space-between; align-items: baseline; gap: 10px; flex-wrap: wrap; font-size: 12px; color: var(--green); font-weight: 600; }
.fold-gate-hint { font-weight: 400; color: var(--muted); font-size: 11px; }
.fold-gate-caveat { font-size: 12px; color: #e3b341; background: rgba(227, 179, 65, 0.1); border: 1px solid rgba(227, 179, 65, 0.35); border-radius: 6px; padding: 6px 8px; }
.fold-gate-text { width: 100%; resize: vertical; font: inherit; font-size: 12px; line-height: 1.5; color: var(--text); background: var(--bg); border: 1px solid var(--line); border-radius: 6px; padding: 8px; box-sizing: border-box; }
.fold-gate-actions { display: flex; gap: 6px; }
.mab-master .mab-continue { display: inline-block; margin-top: 8px; color: var(--green); border-color: rgba(63, 185, 80, 0.4); }
.mab-master-actions .mab-continue { margin-top: 0; }
.mab-master { background: rgba(63, 185, 80, 0.06); border-top: 1px solid var(--line); padding: 10px 12px; }
.mab-master-head { color: var(--green); font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.4px; margin-bottom: 6px; }
.mab-master-text { color: var(--text); font-size: 13px; line-height: 1.55; white-space: pre-wrap; word-break: break-word; }

/* YOLO-milepæl-kort (kloss 1): fase-FSM med status per fase + maskinlesbar verdict */
.ms { margin: 12px 0; border: 1px solid var(--accent-dim); border-radius: 10px; background: var(--panel-2); overflow: hidden; font-family: -apple-system, sans-serif; }
.ms-head { padding: 9px 12px; background: rgba(76, 141, 255, 0.1); color: var(--text); font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.4px; border-bottom: 1px solid var(--line); display: flex; align-items: center; gap: 6px; }
.ms-goal { padding: 8px 12px 4px; font-size: 12.5px; color: var(--text); line-height: 1.5; }
.ms-phases { padding: 6px 12px 10px; display: flex; flex-direction: column; gap: 4px; }
.ms-phase { display: flex; align-items: center; gap: 8px; font-size: 12px; }
.ms-phase-name { color: var(--text); min-width: 200px; }
.ms-phase-meta { color: var(--muted); font-size: 11px; }
.ms-verdict { border-top: 1px solid var(--line); padding: 9px 12px; font-size: 12px; line-height: 1.5; }
.ms-verdict.done { background: rgba(63, 185, 80, 0.08); }
.ms-verdict.failed { background: rgba(248, 81, 73, 0.08); }
.ms-verdict.timeout { background: rgba(227, 179, 65, 0.08); }
.ms-verdict-line { color: var(--text); }
.ms-findings { margin: 6px 0 0; padding-left: 4px; list-style: none; display: flex; flex-direction: column; gap: 3px; }
.ms-findings li { font-size: 11.5px; color: var(--muted); }
.ms-sev { font-size: 10px; font-weight: 700; text-transform: uppercase; padding: 1px 5px; border-radius: 4px; margin-right: 5px; }
.ms-sev.critical { background: rgba(248, 81, 73, 0.2); color: var(--red); }
.ms-sev.high { background: rgba(227, 179, 65, 0.2); color: #e3b341; }
.ms-sev.med, .ms-sev.low { background: var(--line); color: var(--muted); }
.ms-verdict-hint { margin-top: 6px; font-size: 11px; color: var(--muted); }
.ms-verdict-hint code { font-family: var(--font-mono); font-size: 10.5px; background: var(--bg); padding: 1px 4px; border-radius: 4px; word-break: break-all; }

/* Retry-loop (kloss 2): forsøks-badge i hodet, divider mellom forsøk, plateau-varsel */
.ms-attempts { margin-left: auto; font-size: 10px; font-weight: 700; color: #e3b341; background: rgba(227, 179, 65, 0.16); padding: 1px 6px; border-radius: 4px; text-transform: none; letter-spacing: 0; }
.ms-retry { margin: 4px 0 2px; padding: 4px 0 3px; border-top: 1px dashed var(--line); }
.ms-retry-head { font-size: 11px; color: #e3b341; font-weight: 600; display: flex; align-items: center; gap: 8px; }
.ms-retry-toggle { font-size: 10.5px; color: var(--muted); background: none; border: none; cursor: pointer; padding: 0; }
.ms-retry-fb { margin: 4px 0 0; padding: 6px 8px; background: var(--bg); border-radius: 5px; font-family: var(--font-mono); font-size: 10.5px; color: var(--muted); white-space: pre-wrap; word-break: break-word; max-height: 160px; overflow: auto; }
.ms-plateau { margin-top: 6px; font-size: 11.5px; color: #e3b341; }

/* Autopilot (kloss 4): produkt-kort = kjede-oversikt (plan + per-milepæl-status + commits) */
.ms.prod { border-color: rgba(163, 113, 247, 0.5); }
.ms.prod .ms-head { background: rgba(163, 113, 247, 0.12); }
.prod-degraded { padding: 2px 12px 4px; }
/* Regresjons-baseline (kloss 5): grønn = voktet, amber = uvoktet (ingen/ukjent testsuite) */
.prod-baseline { padding: 3px 12px 4px; }
.prod-baseline.clean { color: #3fb950; }
.prod-baseline.unguarded { color: #e3b341; }
.prod-plan { margin: 4px 0 6px; padding: 4px 12px 8px; list-style: none; display: flex; flex-direction: column; gap: 4px; }
.prod-ms { display: flex; align-items: center; gap: 8px; font-size: 12px; color: var(--text); }
.prod-ms.active .prod-ms-title { font-weight: 600; }
.prod-ms.pending .prod-ms-title { color: var(--muted); }
.prod-ms-title { flex: 0 1 auto; }
.prod-sha { font-family: var(--font-mono); font-size: 10px; background: var(--bg); color: var(--muted); padding: 1px 5px; border-radius: 4px; }

/* DoD-quorum (kloss 3): akseptkriterier + per-kriterium ✓/✗ fra dommeren */
.ms-dod { margin: 2px 12px 6px; border: 1px solid var(--line); border-radius: 7px; background: rgba(76, 141, 255, 0.05); }
.ms-dod-head { width: 100%; text-align: left; padding: 6px 9px; font-size: 11.5px; color: var(--text); background: none; border: none; cursor: pointer; }
.ms-dod-body { padding: 0 9px 8px; }
.ms-dod-goal { font-size: 11.5px; color: var(--muted); font-style: italic; margin-bottom: 5px; }
.ms-dod-list { margin: 0; padding: 0; list-style: none; display: flex; flex-direction: column; gap: 3px; }
.ms-dod-item { display: flex; align-items: baseline; gap: 6px; font-size: 11.5px; color: var(--text); }
.ms-dod-mark { font-weight: 700; width: 12px; flex: none; }
.ms-dod-item.met .ms-dod-mark { color: var(--green, #3fb950); }
.ms-dod-item.unmet .ms-dod-mark { color: var(--red); }
.ms-dod-item.pending { color: var(--muted); }
.ms-dod-item.pending .ms-dod-mark { color: var(--muted); }
.ms-dod-id { font-family: var(--font-mono); font-size: 10px; color: var(--muted); flex: none; }
.ms-dod-text { color: inherit; }

/* Apply-til-hovedtre: menneske-styrt port — legg en bestått milepæls isolerte endringer på hovedtreet */
.ms-apply { margin-top: 8px; }
.ms-apply-btn { margin-top: 7px; background: var(--green); color: var(--bg); border: none; font-weight: 600; padding: 6px 12px; border-radius: 6px; font-size: 12px; cursor: pointer; }
.ms-apply-btn:hover:not(:disabled) { filter: brightness(1.08); }
.ms-apply-btn:disabled { opacity: 0.6; cursor: default; }
.ms-apply-res { margin-top: 4px; font-size: 11.5px; line-height: 1.5; color: var(--text); }
.ms-apply-res.done { color: var(--green); }
.ms-apply-res.conflict { color: #e3b341; }
.ms-apply-res.failed { color: var(--red); }
.ms-apply-res code { font-family: var(--font-mono); font-size: 10.5px; background: var(--bg); padding: 1px 4px; border-radius: 4px; word-break: break-all; }

/* Diff-viewer: review NØYAKTIG hva Apply legger på hovedtreet, før du trykker */
.ms-apply-actions { display: flex; gap: 8px; align-items: center; margin-top: 7px; flex-wrap: wrap; }
.ms-diff-btn { font-size: 11.5px; }
.ms-diff { margin-top: 8px; border: 1px solid var(--line); border-radius: 8px; overflow: hidden; background: var(--bg); }
.ms-diff-msg { padding: 8px 12px; font-size: 11.5px; color: var(--muted); }
.ms-diff-msg.err { color: var(--red); }
.ms-diff-banner { padding: 6px 12px; font-size: 11px; font-weight: 600; border-bottom: 1px solid var(--line); }
.ms-diff-banner.clean { color: var(--green); background: rgba(63, 185, 80, 0.08); }
.ms-diff-banner.threeway { color: #e3b341; background: rgba(227, 179, 65, 0.08); }
.ms-diff-body { margin: 0; padding: 6px 0; max-height: 320px; overflow: auto; font-family: var(--font-mono); font-size: 11px; line-height: 1.45; white-space: pre; }
.ms-diff-body .dl { padding: 0 12px; }
.ms-diff-body .dl.add { background: rgba(63, 185, 80, 0.12); color: #56d364; }
.ms-diff-body .dl.del { background: rgba(248, 81, 73, 0.12); color: #f85149; }
.ms-diff-body .dl.hunk { color: #79c0ff; background: rgba(56, 139, 253, 0.08); }
.ms-diff-body .dl.meta { color: var(--muted); }
.ms-diff-trunc { padding: 6px 12px; font-size: 10.5px; color: var(--muted); border-top: 1px solid var(--line); }

/* Subagent-tre: én headless agent sine interne `Agent`-subagenter, status per subagent (FleetView) */
.subs { margin: 10px 0; border: 1px solid var(--line); border-radius: 9px; background: var(--panel-2); overflow: hidden; font-family: -apple-system, sans-serif; }
.subs-head { padding: 7px 12px; font-size: 11px; font-weight: 600; color: var(--muted); text-transform: uppercase; letter-spacing: 0.4px; width: 100%; text-align: left; }
.subs-list { border-top: 1px solid var(--line); display: flex; flex-direction: column; }
.subrow { padding: 7px 12px; border-bottom: 1px solid var(--line); display: flex; flex-direction: column; gap: 3px; }
.subrow:last-child { border-bottom: none; }
.subrow.running { background: rgba(76, 141, 255, 0.05); }
.subrow.failed { background: rgba(248, 81, 73, 0.06); }
.subrow-head { display: flex; align-items: center; gap: 7px; font-size: 12px; }
.subrow-type { color: var(--accent); font-weight: 600; font-size: 11px; white-space: nowrap; }
.subrow-desc { color: var(--text); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; flex: 1; }
.subrow-tok { color: var(--muted); font-family: var(--font-mono); font-size: 10.5px; white-space: nowrap; }
.subrow-live { color: var(--muted); font-size: 11.5px; padding-left: 21px; font-style: italic; }
.subrow-toggle { font-size: 10.5px; padding: 1px 0 1px 21px; align-self: flex-start; }
.subrow-acts { padding-left: 21px; display: flex; flex-direction: column; gap: 2px; margin-top: 2px; }
.subact { font-size: 11.5px; color: var(--muted); font-family: var(--font-mono); white-space: pre-wrap; word-break: break-word; }

/* Agent-plan-kort (TodoWrite → avkrysning → gjøremål / sekvensiell kjøring) */
.todocap { margin: 10px 0; border: 1px solid var(--line); border-radius: 9px; background: var(--panel-2); overflow: hidden; font-family: -apple-system, sans-serif; }
.todocap.latest { border-color: var(--accent-dim); }
.todocap-head { display: block; width: 100%; text-align: left; padding: 8px 12px; font-size: 11.5px; }
.todocap.latest .todocap-head { color: var(--accent); }
.todocap-list { display: flex; flex-direction: column; gap: 1px; background: var(--line); border-top: 1px solid var(--line); }
.todocap-item { display: flex; align-items: flex-start; gap: 8px; padding: 7px 12px; background: var(--panel-2); font-size: 12.5px; line-height: 1.45; color: var(--text); cursor: pointer; }
.todocap-item input { margin-top: 2px; flex: none; }
.todocap-badge { color: var(--muted); }
.todocap-item.in_progress .todocap-badge { color: var(--accent); }
.todocap-item.completed .todocap-badge { color: var(--green); }
.todocap-item.completed .todocap-text { color: var(--muted); text-decoration: line-through; }
.todocap-text { flex: 1; word-break: break-word; }
.todocap-foot { display: flex; flex-wrap: wrap; align-items: center; gap: 8px; padding: 9px 12px; border-top: 1px dashed var(--line); }
.todocap-count { color: var(--muted); font-size: 11px; margin-right: auto; }
.todocap-run { color: var(--accent); border-color: var(--accent-dim); }

/* Dock (høyre, kollapsbar) */
.dock { overflow: hidden; }
.tabs { display: flex; gap: 4px; }
.tab {
  background: transparent; color: var(--muted); border: 1px solid transparent;
  border-radius: 6px; padding: 4px 10px; font-size: 11px; font-weight: 500;
}
.tab:hover { color: var(--text); }
.tab.active { background: var(--panel); color: var(--accent); border-color: var(--accent-dim); }
.collapse { background: transparent; color: var(--muted); border: 1px solid var(--line); border-radius: 6px; padding: 2px 9px; font-size: 13px; }
.dockreopen { margin-left: auto; }

.view { flex: 1; min-height: 0; display: flex; flex-direction: column; }
.hint.pad { padding: 14px; }
.subbar { display: flex; gap: 6px; padding: 8px 10px; border-bottom: 1px solid var(--line); background: var(--panel); }
.subbar input { flex: 1; font-family: var(--font-mono); font-size: 11px; }
.webview { flex: 1; border: none; background: #fff; }

/* Prosjekt-info */
.proj-info { overflow-y: auto; padding: 14px; }
.proj-info h3 { margin: 0 0 12px; font-size: 15px; color: var(--text); }
.kv { display: flex; gap: 10px; margin-bottom: 7px; font-size: 12px; align-items: baseline; }
.kv > span { color: var(--muted); min-width: 54px; text-transform: uppercase; font-size: 10px; letter-spacing: 0.5px; }
.kv code { color: var(--text); font-family: var(--font-mono); font-size: 11.5px; word-break: break-all; }
.kv-label { color: var(--muted); text-transform: uppercase; font-size: 10px; letter-spacing: 0.6px; margin: 16px 0 8px; }
.scripts { display: flex; flex-direction: column; gap: 5px; }
.script { display: flex; gap: 10px; align-items: baseline; }
.script .sk { color: var(--accent); font-family: var(--font-mono); font-size: 11.5px; min-width: 90px; }
.script .sv { color: var(--muted); font-family: var(--font-mono); font-size: 11px; word-break: break-all; }
.readme {
  white-space: pre-wrap; word-break: break-word; color: var(--muted); font-family: var(--font-mono);
  font-size: 11px; line-height: 1.5; background: var(--bg); border: 1px solid var(--line);
  border-radius: 8px; padding: 10px; margin: 0;
}

/* Notater */
.view-notes { padding: 10px; }
.notes {
  flex: 1; width: 100%; resize: none; background: var(--bg); color: var(--text);
  border: 1px solid var(--line); border-radius: 8px; padding: 12px;
  font-family: var(--font-mono); font-size: 12px; line-height: 1.6;
}

/* Bruk-fane (usage + kontekst) */
.usage-view { overflow-y: auto; padding: 14px; }
.ctx-meter { margin: 6px 0 16px; }
.ctx-bar { height: 8px; background: var(--bg); border: 1px solid var(--line); border-radius: 6px; overflow: hidden; }
.ctx-fill { height: 100%; background: var(--accent); transition: width 0.3s; }
.ctx-num { color: var(--muted); font-family: var(--font-mono); font-size: 11px; margin-top: 5px; }
.usage-row { display: flex; flex-direction: column; gap: 2px; padding: 7px 0; border-bottom: 1px solid var(--line); }
.usage-model { font-size: 12.5px; color: var(--text); }
.usage-nums { font-family: var(--font-mono); font-size: 11px; color: var(--muted); }
.usage-total { margin-top: 10px; font-family: var(--font-mono); font-size: 12px; color: var(--green); }
.usage-note { margin-top: 14px; font-size: 10.5px; line-height: 1.5; }
.sess.ctx { color: var(--amber); margin-left: 6px; }

/* Konsultasjons-historikk (durable ledger) */
.consult-view { overflow-y: auto; padding: 10px; }
.consult-head { display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.consult-head .kv-label { margin: 6px 0 8px; }
.consult-round { border: 1px solid var(--line); border-radius: 7px; margin-bottom: 7px; overflow: hidden; }
.consult-round-head { display: flex; align-items: center; gap: 8px; width: 100%; text-align: left; background: transparent; border: 0; padding: 8px 10px; cursor: pointer; color: var(--text); }
.consult-round-head:hover { background: rgba(255, 255, 255, 0.03); }
.consult-badge { flex: none; width: 16px; text-align: center; font-size: 12px; }
.consult-badge.folded, .consult-badge.done { color: var(--green); }
.consult-badge.partial { color: #e3b341; }
.consult-badge.failed { color: var(--red, #f85149); }
.consult-badge.running { color: var(--accent); }
.consult-brief { flex: 1; font-size: 12.5px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.consult-meta { flex: none; font-family: var(--font-mono); font-size: 10px; color: var(--muted); }
.consult-body { padding: 8px 10px; border-top: 1px solid var(--line); background: var(--bg); display: flex; flex-direction: column; gap: 8px; }
.consult-answer, .consult-synth { display: flex; flex-direction: column; gap: 4px; }
.consult-synth { border-top: 1px dashed var(--line); padding-top: 8px; }
.consult-answer-head { display: flex; align-items: center; justify-content: space-between; gap: 8px; font-size: 11.5px; color: var(--muted); font-weight: 600; }
.consult-answer-text { font-size: 12px; line-height: 1.5; color: var(--text); white-space: pre-wrap; word-break: break-word; max-height: 180px; overflow-y: auto; }
