/*
 * Portal styles — implements the shared Factory of Agents portal header standard
 * (standards/portal-header.md; SPEC-Agent.md §7.1, SPEC-FactoryOfAgents.md §11) plus
 * the agent sub-tab chrome (§7.2). Modern, light, low-chrome: the header recedes so
 * portal content leads. Brand mark: Claidio hex-shield (/static/cld-logo.svg).
 * Brand tokens mirror the canonical Claidio set (standards/claidio-branding.html).
 */
:root {
  --cld-ink: #0F172A;
  --cld-paper: #F8FAFC;
  --cld-mist: #E2E8F0;
  --cld-fog: #94A3B8;
  --cld-primary: #1E3A8A;   /* Claidio primary */
  --cld-primary-2: #2563EB;
  --cld-sky: #0EA5E9;
  --cld-violet: #7C3AED;
  --cld-rose: #E11D48;
  --cld-mint: #10B981;
  --cld-amber: #F59E0B;
  --cld-radius-sm: 6px;
  --cld-radius-md: 12px;
  --cld-radius-lg: 24px;
  --cld-shadow-sm: 0 1px 2px rgba(15, 23, 42, .08);
  --cld-shadow-md: 0 8px 24px rgba(15, 23, 42, .10);
}

* { box-sizing: border-box; }

body {
  margin: 0;
  font-family: Inter, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  color: var(--cld-ink);
  background: var(--cld-paper);
  font-size: 14px;
  line-height: 1.5;
}

a { color: var(--cld-primary-2); text-decoration: none; }
a:hover { text-decoration: underline; }

/* ---- Header (Factory of Agents standard, portal-header.md §1–§2) ------------------- */
.cld-header {
  position: sticky;
  top: 0;
  z-index: 50;
  display: flex;
  align-items: center;
  gap: 16px;
  height: 64px;
  padding: 0 24px;
  background: #FFFFFF;
  border-bottom: 1px solid var(--cld-mist);
}
.cld-portal-switcher {
  display: grid;
  grid-template-columns: repeat(3, 4px);
  grid-template-rows: repeat(3, 4px);
  gap: 3px;
  padding: 8px;
  border-radius: var(--cld-radius-sm);
  cursor: pointer;
  border: none;
  background: transparent;
}
.cld-portal-switcher span { width: 4px; height: 4px; border-radius: 50%; background: var(--cld-ink); }
.cld-portal-switcher:hover { background: var(--cld-mist); }

.cld-brand { display: flex; align-items: center; gap: 10px; }
.cld-logo { height: 28px; width: auto; display: block; }   /* Claidio hex-shield (cld-logo.svg) */
.cld-wordmark { font-weight: 600; font-size: 18px; letter-spacing: -.01em; color: var(--cld-ink); }
.cld-subbrand {
  padding-left: 12px; margin-left: 4px;
  border-left: 1px solid var(--cld-mist);
  color: var(--cld-fog); font-size: 14px;
}

.cld-spacer { flex: 1; }

.cld-search {
  flex: 1; max-width: 720px;
  display: flex; align-items: center; gap: 8px;
  height: 40px; padding: 0 14px;
  background: var(--cld-paper);
  border: 1px solid var(--cld-mist);
  border-radius: var(--cld-radius-md);
  color: var(--cld-fog);
}
.cld-search input {
  border: none; outline: none; background: transparent;
  flex: 1; font: inherit; color: var(--cld-ink);
}
.cld-search .kbd {
  font-size: 11px; color: var(--cld-fog);
  border: 1px solid var(--cld-mist); border-radius: 4px;
  padding: 1px 5px;
}

.cld-user { position: relative; }
.cld-avatar {
  width: 32px; height: 32px; border-radius: 50%;
  display: grid; place-items: center;
  color: #fff; font-weight: 600; font-size: 13px;
  background: var(--cld-primary-2);
  border: none; cursor: pointer;
}
.cld-avatar:focus-visible { outline: 2px solid var(--cld-primary-2); outline-offset: 2px; }
.cld-usermenu {
  position: absolute; right: 0; top: 42px;
  width: 240px; background: #fff;
  border: 1px solid var(--cld-mist);
  border-radius: var(--cld-radius-md);
  box-shadow: var(--cld-shadow-md);
  padding: 6px; display: none;
}
.cld-usermenu.open { display: block; }
.cld-usermenu .who { padding: 10px 12px; border-bottom: 1px solid var(--cld-mist); }
.cld-usermenu .who .name { font-weight: 600; }
.cld-usermenu .who .sub { color: var(--cld-fog); font-size: 12px; }
.cld-usermenu a, .cld-usermenu button {
  display: block; width: 100%; text-align: left;
  padding: 9px 12px; border-radius: 6px;
  color: var(--cld-ink); background: none; border: none;
  font: inherit; cursor: pointer; text-decoration: none;
}
.cld-usermenu a:hover, .cld-usermenu button:hover { background: var(--cld-paper); text-decoration: none; }
.cld-usermenu .logout { color: var(--cld-rose); border-top: 1px solid var(--cld-mist); margin-top: 4px; }
.cld-badge-admin {
  font-size: 11px; font-weight: 600; color: var(--cld-primary-2);
  background: rgba(37, 99, 235, .1); border-radius: 4px; padding: 1px 6px; margin-left: 6px;
}

/* ---- Sub-tabs (SPEC.md §7.2) -------------------------------------------- */
.subtabs {
  display: flex; gap: 4px;
  padding: 0 24px;
  background: #fff;
  border-bottom: 1px solid var(--cld-mist);
  overflow-x: auto;
}
.subtabs a {
  padding: 12px 14px;
  color: var(--cld-fog);
  font-weight: 500;
  border-bottom: 2px solid transparent;
  white-space: nowrap;
}
.subtabs a:hover { color: var(--cld-ink); text-decoration: none; }
.subtabs a.active { color: var(--cld-primary-2); border-bottom-color: var(--cld-primary-2); }

/* ---- Layout ------------------------------------------------------------- */
.page { max-width: 1100px; margin: 0 auto; padding: 24px; }
.page h1 { font-size: 20px; margin: 0 0 4px; }
.page .lede { color: var(--cld-fog); margin: 0 0 20px; }

.card {
  background: #fff; border: 1px solid var(--cld-mist);
  border-radius: var(--cld-radius-lg); padding: 20px;
}
.muted { color: var(--cld-fog); }

.btn {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 9px 16px; border-radius: var(--cld-radius-md);
  background: var(--cld-primary-2); color: #fff; font-weight: 600;
  border: none; cursor: pointer; font: inherit;
}
.btn:hover { filter: brightness(.95); text-decoration: none; }
.btn.secondary { background: #fff; color: var(--cld-ink); border: 1px solid var(--cld-mist); }
.btn[disabled] { opacity: .5; cursor: not-allowed; }
/* Ghost button — used for the composer's attach (📎) control (SPEC-Agent.md §9.4). */
.btn-ghost { background: #fff; color: var(--cld-ink); border: 1px solid var(--cld-mist); }
.attach-list { padding: 6px 12px; font-size: 13px; }

textarea.editor {
  width: 100%; min-height: 460px;
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
  font-size: 13px; line-height: 1.6;
  padding: 14px; border: 1px solid var(--cld-mist);
  border-radius: var(--cld-radius-md); resize: vertical;
}

.flash { padding: 10px 14px; border-radius: var(--cld-radius-md); margin-bottom: 16px; font-weight: 500; }
.flash.ok { background: rgba(16, 185, 129, .12); color: #047857; }
.flash.err { background: rgba(225, 29, 72, .1); color: var(--cld-rose); }
.readonly-note { font-size: 12px; color: var(--cld-fog); margin-bottom: 12px; }

/* rendered markdown */
.md { line-height: 1.65; }
.md h1, .md h2, .md h3 { line-height: 1.3; }
.md code { background: var(--cld-paper); padding: 2px 5px; border-radius: 4px; font-size: 12.5px; }
.md pre { background: var(--cld-paper); padding: 14px; border-radius: var(--cld-radius-md); overflow-x: auto; }
.md table { border-collapse: collapse; width: 100%; }
.md th, .md td { border: 1px solid var(--cld-mist); padding: 6px 10px; text-align: left; }
.md blockquote { border-left: 3px solid var(--cld-mist); margin: 0; padding-left: 14px; color: var(--cld-fog); }

/* ---- Interact / chat ---------------------------------------------------- */
.chat-layout { display: grid; grid-template-columns: 280px 1fr; gap: 20px; align-items: start; }
.conv-list { background: #fff; border: 1px solid var(--cld-mist); border-radius: var(--cld-radius-lg); overflow: hidden; }
.conv-list .head { padding: 14px 16px; border-bottom: 1px solid var(--cld-mist); display: flex; justify-content: space-between; align-items: center; }
.conv-list .head .btn { padding: 6px 10px; font-size: 12px; }
.conv-item { padding: 11px 16px; border-bottom: 1px solid var(--cld-mist); cursor: pointer; }
.conv-item:hover { background: var(--cld-paper); }
.conv-item.active { background: rgba(37, 99, 235, .07); border-left: 3px solid var(--cld-primary-2); }
.conv-item .title { font-weight: 500; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.conv-item .meta { font-size: 11px; color: var(--cld-fog); }
.conv-item .owner { font-size: 11px; color: var(--cld-primary-2); }

.chat { display: flex; flex-direction: column; height: calc(100vh - 220px); min-height: 460px; background: #fff; border: 1px solid var(--cld-mist); border-radius: var(--cld-radius-lg); }
.messages { flex: 1; overflow-y: auto; padding: 18px; display: flex; flex-direction: column; gap: 14px; }
.msg { max-width: 80%; padding: 11px 14px; border-radius: 14px; white-space: pre-wrap; word-wrap: break-word; }
.msg.user { align-self: flex-end; background: var(--cld-primary-2); color: #fff; border-bottom-right-radius: 4px; }
.msg.assistant { align-self: flex-start; background: var(--cld-paper); border: 1px solid var(--cld-mist); border-bottom-left-radius: 4px; }
.msg.assistant .md { line-height: 1.5; }
.msg.assistant .md p:first-child { margin-top: 0; }
.msg.assistant .md p:last-child { margin-bottom: 0; }
.composer { display: flex; gap: 10px; padding: 14px; border-top: 1px solid var(--cld-mist); }
.composer textarea { flex: 1; resize: none; height: 46px; padding: 12px 14px; border: 1px solid var(--cld-mist); border-radius: var(--cld-radius-md); font: inherit; }
.empty-state { color: var(--cld-fog); text-align: center; margin: auto; max-width: 380px; }
.typing { align-self: flex-start; color: var(--cld-fog); font-style: italic; }

/* ---- Logs --------------------------------------------------------------- */
/* Logs filter/search toolbar (Factory Logs tab, SPEC-FactoryOfAgents.md §9). */
.logs-filter { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; margin-bottom: 12px; }
.logs-filter input[type=text], .logs-filter select {
  padding: 8px 12px; border: 1px solid var(--cld-mist); border-radius: var(--cld-radius-md);
  font: inherit; background: #fff; color: var(--cld-ink);
}
.logs-filter input[type=text] { flex: 1 1 220px; min-width: 180px; }
.logs-empty { padding: 16px; }
.logs-table { width: 100%; border-collapse: collapse; font-size: 12.5px; }
.logs-table th, .logs-table td { border-bottom: 1px solid var(--cld-mist); padding: 8px 10px; text-align: left; vertical-align: top; }
.logs-table th { color: var(--cld-fog); font-weight: 600; }
.logs-table td.mono { font-family: ui-monospace, monospace; }
.tag { display: inline-block; font-size: 11px; padding: 1px 7px; border-radius: 999px; font-weight: 600; }
.tag.user_message { background: rgba(37,99,235,.1); color: var(--cld-primary-2); }
.tag.model_call, .tag.model_response { background: rgba(16,185,129,.12); color: #047857; }
.tag.tool_call, .tag.tool_result { background: rgba(245,158,11,.15); color: #B45309; }
.tag.cron_run { background: rgba(99,102,241,.12); color: #4F46E5; }
.tag.auth { background: var(--cld-mist); color: var(--cld-ink); }
.tag.error { background: rgba(225,29,72,.12); color: var(--cld-rose); }

/* ---- Index / agent list & login ---------------------------------------- */
.center-wrap { min-height: 70vh; display: grid; place-items: center; }
.login-card { width: 360px; }
.login-card h1 { margin-top: 0; }
.login-card input[type=text] { width: 100%; padding: 11px 14px; border: 1px solid var(--cld-mist); border-radius: var(--cld-radius-md); font: inherit; margin-bottom: 12px; }
.agent-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 16px; }
.agent-tile { display: block; background: #fff; border: 1px solid var(--cld-mist); border-radius: var(--cld-radius-lg); padding: 18px; }
.agent-tile:hover { box-shadow: var(--cld-shadow-md); text-decoration: none; }
.agent-tile .name { font-weight: 600; font-size: 16px; }
.agent-tile .desc { color: var(--cld-fog); margin-top: 6px; font-size: 13px; }
.chips { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 12px; }
.chip { font-size: 11px; padding: 2px 8px; border-radius: 999px; border: 1px solid var(--cld-mist); color: var(--cld-fog); }
.chip.on { color: var(--cld-mint); border-color: rgba(16,185,129,.4); }
.chip.off { color: var(--cld-fog); }

/* ---- Network (live interaction graph, §8.3) ----------------------------- */
.graph-toolbar {
  display: flex; align-items: center; justify-content: space-between;
  gap: 16px; flex-wrap: wrap; margin-bottom: 12px;
}
.graph-legend { display: flex; flex-wrap: wrap; gap: 14px; }
.legend-item { display: inline-flex; align-items: center; gap: 6px; font-size: 12px; color: var(--cld-fog); text-transform: capitalize; }
.legend-item .swatch, .gd-title .swatch {
  width: 11px; height: 11px; border-radius: 3px; display: inline-block; flex: none;
}
.graph-live { display: inline-flex; align-items: center; gap: 8px; font-size: 12.5px; }
.live-dot { width: 9px; height: 9px; border-radius: 50%; background: var(--cld-mist); flex: none; }
.live-dot.on { background: var(--cld-mint); box-shadow: 0 0 0 0 rgba(16,185,129,.6); animation: liveBlink 1.4s ease-out infinite; }
@keyframes liveBlink {
  0%   { box-shadow: 0 0 0 0 rgba(16,185,129,.55); }
  70%  { box-shadow: 0 0 0 7px rgba(16,185,129,0); }
  100% { box-shadow: 0 0 0 0 rgba(16,185,129,0); }
}

.graph-wrap { position: relative; padding: 0; overflow: hidden; }
.graph-svg {
  display: block; width: 100%; height: 560px;
  background:
    radial-gradient(circle at 1px 1px, var(--cld-mist) 1px, transparent 0) 0 0 / 22px 22px,
    #fff;
  touch-action: none;
}
.graph-empty {
  position: absolute; inset: 0; display: grid; place-items: center;
  text-align: center; padding: 24px; pointer-events: none; line-height: 1.7;
}
.graph-empty a { pointer-events: auto; }
.graph-hint { font-size: 12px; margin-top: 10px; }

/* edges */
.gedge { stroke-opacity: .35; stroke-linecap: round; transition: stroke-opacity .25s; cursor: pointer; }
.gedge-group:hover .gedge { stroke-opacity: .8; }
.gedge-group.active .gedge { stroke-opacity: .9; }
.gedge-group.selected .gedge { stroke-opacity: 1; }
.gedge-group.flash .gedge { animation: edgeFlash 1.2s ease-out; }
@keyframes edgeFlash { 0% { stroke-opacity: 1; stroke-width: 9; } 100% { stroke-opacity: .9; } }
.particle { filter: drop-shadow(0 0 4px currentColor); }

/* nodes */
.gnode { cursor: pointer; }
.gnode .halo { fill: none; stroke-width: 2.5px; opacity: .55; }
.gnode .dot { stroke-width: 2px; transition: stroke-width .15s; }
.gnode.agent .dot { fill: var(--cld-primary-2); stroke: #1E3A8A; }
.gnode.user .dot { fill: #fff; stroke: var(--cld-fog); }
.gnode.user.active .dot { stroke: var(--cld-mint); }
.gnode.selected .dot { stroke-width: 3.5px; stroke: var(--cld-primary-2); }
.gnode.flash .dot { animation: nodeFlash .9s ease-out; }
@keyframes nodeFlash { 0% { stroke-width: 6px; } 100% { stroke-width: 2px; } }
.gnode .glyph {
  text-anchor: middle; font-size: 12px; font-weight: 700; pointer-events: none;
  fill: #fff;
}
.gnode.user .glyph { fill: var(--cld-fog); }
.gnode.user.active .glyph { fill: #047857; }
.gnode .label {
  text-anchor: middle; font-size: 11.5px; font-weight: 500;
  fill: var(--cld-ink); pointer-events: none; paint-order: stroke;
  stroke: #fff; stroke-width: 3px;
}

/* detail panel */
.graph-detail {
  position: absolute; top: 14px; right: 14px; width: 230px;
  background: #fff; border: 1px solid var(--cld-mist);
  border-radius: var(--cld-radius-md); box-shadow: var(--cld-shadow-md);
  padding: 14px 14px 10px;
}
.graph-detail-close {
  position: absolute; top: 6px; right: 8px; border: none; background: none;
  font-size: 18px; line-height: 1; color: var(--cld-fog); cursor: pointer;
}
.gd-title { font-weight: 600; display: flex; align-items: center; gap: 7px; padding-right: 16px; }
.gd-live {
  font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .04em;
  color: #047857; background: rgba(16,185,129,.14); border-radius: 4px; padding: 1px 6px;
}
.gd-kind { font-size: 12px; color: var(--cld-fog); text-transform: capitalize; margin: 2px 0 10px; }
.gd-row { display: flex; justify-content: space-between; gap: 10px; font-size: 12.5px; padding: 4px 0; border-top: 1px solid var(--cld-mist); }
.gd-row span { color: var(--cld-fog); }

@media (max-width: 768px) {
  .chat-layout { grid-template-columns: 1fr; }
  .cld-subbrand, .cld-search .kbd { display: none; }
  .graph-svg { height: 440px; }
  .graph-detail { width: 190px; }
}

/* ---- Factory: Agents overview tiles (SPEC-FactoryOfAgents.md §9.1) ------- */
.tile-head { display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.health { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .03em; padding: 2px 8px; border-radius: 999px; }
.health.up { background: rgba(16,185,129,.14); color: #047857; }
.health.degraded { background: rgba(245,158,11,.16); color: #B45309; }
.health.down { background: rgba(225,29,72,.12); color: var(--cld-rose); }
.tile-meta { margin-top: 10px; font-size: 12.5px; }
.skills { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 10px; }
.skill-pill { font-size: 11px; padding: 2px 8px; border-radius: 6px; background: rgba(124,58,237,.10); color: #6D28D9; font-family: ui-monospace, monospace; }

/* ---- Factory: two-column tab layouts ------------------------------------ */
.two-col { display: grid; grid-template-columns: 1.4fr 1fr; gap: 20px; align-items: start; }
.field-label { display: block; font-size: 12px; font-weight: 600; color: var(--cld-fog); margin-bottom: 5px; }
.route-result { margin-top: 18px; padding-top: 16px; border-top: 1px solid var(--cld-mist); }
.rr-head { display: flex; align-items: center; gap: 10px; }
@media (max-width: 820px) { .two-col { grid-template-columns: 1fr; } }

/* fleet-graph detail "open agent" link */
.gd-link { display: inline-block; margin-top: 10px; font-size: 13px; font-weight: 600; }
