/* fleet.css — Fleet Command Center. Layered on main.css design tokens.
   Generated pages: fleet/index.html, fleet/<agent>.html, fleet/cowork.html */

.fleet-hero{padding:3.2rem 0 1.8rem;border-bottom:1px solid var(--border);
  background:linear-gradient(180deg,var(--bg-card),transparent)}
.fleet-eyebrow{font-family:var(--font-sans);font-size:.72rem;letter-spacing:.28em;
  font-weight:700;color:var(--gold);margin-bottom:.6rem}
.fleet-hero h1{font-family:var(--font-main);font-size:clamp(2rem,4vw,3rem);
  margin:0 0 .5rem;line-height:1.05}
.fleet-sub{color:var(--gray);max-width:60ch;font-size:1.02rem}
.live-badge{display:inline-flex;align-items:center;gap:.5rem;margin-top:1rem;font-size:.72rem;
  letter-spacing:.12em;font-weight:700;color:var(--gray);background:var(--bg-card);
  border:1px solid var(--border);border-radius:20px;padding:.32rem .8rem}
.live-dot{width:8px;height:8px;border-radius:50%;background:#2E9E5B;
  box-shadow:0 0 0 0 rgba(46,158,91,.6);animation:livepulse 2.4s infinite}
@keyframes livepulse{0%{box-shadow:0 0 0 0 rgba(46,158,91,.55)}70%{box-shadow:0 0 0 7px rgba(46,158,91,0)}100%{box-shadow:0 0 0 0 rgba(46,158,91,0)}}

/* stat strip */
.stat-strip{display:grid;grid-template-columns:repeat(6,1fr);gap:.6rem;margin-top:1.6rem}
.stat{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);
  padding:.85rem 1.1rem}
@media(max-width:900px){.stat-strip{grid-template-columns:repeat(3,1fr)}}
@media(max-width:520px){.stat-strip{grid-template-columns:repeat(2,1fr)}}

/* needs-attention banner */
.health-banner{display:flex;gap:.9rem;align-items:flex-start;background:rgba(224,161,0,.08);
  border:1px solid rgba(224,161,0,.35);border-left:4px solid #E0A100;border-radius:var(--radius);
  padding:.9rem 1.1rem}
.health-icon{flex:none;width:26px;height:26px;border-radius:50%;background:#E0A100;color:#1a1a1a;
  font-weight:800;display:flex;align-items:center;justify-content:center;font-size:1rem}
.health-title{font-family:var(--font-main);font-weight:700;color:var(--white);margin-bottom:.25rem}
.health-list{list-style:none;margin:0;padding:0;font-size:.88rem;color:var(--gray)}
.health-list li{padding:.12rem 0}
.health-list a{font-weight:600;text-decoration:none}
.stat-n{font-family:var(--font-main);font-size:1.9rem;font-weight:700;line-height:1;color:var(--white)}
.stat-l{font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gray);margin-top:.35rem}
.status-good{color:#2E9E5B}.status-bad{color:#C0392B}

/* section scaffolding */
.fleet-section{padding:2.4rem 0}
.section-head{font-family:var(--font-main);font-size:1.5rem;margin:0 0 .3rem;
  padding-bottom:.4rem;border-bottom:1px solid var(--border)}
.section-note{color:var(--gray);font-size:.9rem;margin:.5rem 0 1.2rem}

/* filter bar */
.filter-bar{display:flex;flex-wrap:wrap;gap:.7rem;align-items:center;justify-content:space-between;margin-bottom:1.1rem}
.filter-group{display:inline-flex;gap:.3rem;background:var(--bg-card);border:1px solid var(--border);
  border-radius:30px;padding:.25rem}
.fbtn{font-family:var(--font-sans);font-size:.78rem;font-weight:600;color:var(--gray);background:none;
  border:none;border-radius:24px;padding:.4rem .9rem;cursor:pointer;transition:var(--transition);white-space:nowrap}
.fbtn:hover{color:var(--white)}
.fbtn.active{background:var(--gold);color:var(--bg-dark)}
.filter-domain{font-family:var(--font-sans);font-size:.82rem;color:var(--white);background:var(--bg-card);
  border:1px solid var(--border);border-radius:24px;padding:.45rem 1rem;cursor:pointer}
.filter-empty{color:var(--gray);text-align:center;padding:2rem 0}

/* agent grid + cards */
.agent-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:1rem}
.agent-card{display:block;background:var(--bg-card);border:1px solid var(--border);
  border-left:3px solid var(--ac);border-radius:var(--radius);padding:1.1rem 1.15rem;
  text-decoration:none;color:inherit;transition:var(--transition);position:relative}
.agent-card:hover{transform:translateY(-3px);border-color:var(--ac);
  box-shadow:0 10px 28px rgba(0,0,0,.3), 0 0 0 1px var(--ac),
             0 6px 26px color-mix(in srgb,var(--ac) 26%,transparent)}
.agent-card-top{display:flex;align-items:center;gap:.75rem;margin-bottom:.7rem}
.agent-card-id{flex:1;min-width:0}
.agent-name{font-family:var(--font-main);font-weight:700;font-size:1.08rem;color:var(--white);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.agent-callsign{font-size:.7rem;letter-spacing:.08em;color:var(--gray);text-transform:uppercase;margin-top:.1rem}
.agent-blurb{color:var(--gray);font-size:.86rem;line-height:1.45;margin:0 0 .8rem;
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.agent-card-meta{display:flex;flex-wrap:wrap;gap:.4rem 1rem;font-size:.74rem;color:var(--gray);
  border-top:1px solid var(--border);padding-top:.6rem}
.agent-card-meta span:first-child{color:var(--gold);font-weight:600}

/* logos / monograms */
.agent-logo{display:inline-flex;align-items:center;justify-content:center;flex:none;
  border-radius:50%;overflow:hidden;background:var(--bg-dark);
  border:2px solid var(--ac);position:relative}
.agent-logo img{width:100%;height:100%;object-fit:cover;display:block}
.agent-mono{font-family:var(--font-main);font-weight:700;color:var(--ac);
  align-items:center;justify-content:center;width:100%;height:100%;font-size:.9em;
  background:color-mix(in srgb,var(--ac) 14%,var(--bg-card))}

/* status dots */
.status-dot{width:11px;height:11px;border-radius:50%;flex:none;display:inline-block}
.dot-operational{background:#2E9E5B;box-shadow:0 0 0 3px rgba(46,158,91,.18)}
.dot-degraded{background:#E0A100;box-shadow:0 0 0 3px rgba(224,161,0,.18)}
.dot-standby{background:#6B7280;box-shadow:0 0 0 3px rgba(107,114,128,.16)}
.dot-unknown{background:#444}
.feed-dot{width:8px;height:8px;border-radius:50%;display:inline-block;flex:none}
.dot-ok{background:#2E9E5B}.dot-warn{background:#E0A100}.dot-muted{background:#6B7280}

/* job spark bar */
.job-spark{display:flex;gap:3px;flex-wrap:wrap;margin-top:.7rem}
.pill{width:13px;height:5px;border-radius:2px;display:inline-block}
.pill-ok{background:#2E9E5B}.pill-warn{background:#E0A100}.pill-off{background:var(--border)}

/* split: feed + wins */
.split{display:grid;grid-template-columns:1.4fr 1fr;gap:2rem;align-items:start}
.feed{list-style:none;padding:0;margin:0}
.feed li{display:flex;align-items:center;gap:.7rem;padding:.55rem 0;border-bottom:1px solid var(--border);font-size:.88rem}
.feed-agent{font-weight:600;flex:none;min-width:120px}
.feed-job{color:var(--gray);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.feed-time{color:var(--gray);font-size:.78rem;flex:none}

/* accomplishments */
.acc-reel{display:flex;flex-direction:column;gap:.7rem}
.agent-acc{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:.8rem}
.acc-item{display:flex;gap:.8rem;background:var(--bg-card);border:1px solid var(--border);
  border-left:3px solid var(--ac);border-radius:var(--radius);padding:.8rem .9rem}
.acc-date{font-family:var(--font-main);font-size:.74rem;color:var(--gold);font-weight:700;
  flex:none;width:74px;padding-top:.1rem}
.acc-agent{font-size:.72rem;color:var(--ac);text-decoration:none;font-weight:700;text-transform:uppercase;letter-spacing:.05em}
.acc-title{font-weight:600;color:var(--white);font-size:.92rem;margin:.1rem 0 .15rem}
.acc-detail{color:var(--gray);font-size:.83rem;line-height:1.4}

/* ── agent deep-dive ── */
.agent-hero{padding:2.6rem 0;border-bottom:1px solid var(--border);
  background:linear-gradient(120deg,color-mix(in srgb,var(--ac) 12%,var(--bg-card)),transparent)}
.agent-hero-inner{display:flex;align-items:center;gap:1.6rem;flex-wrap:wrap}
.agent-hero-id h1{font-family:var(--font-main);font-size:clamp(1.8rem,3.5vw,2.6rem);margin:.1rem 0}
.agent-hero .agent-callsign{font-size:.8rem;letter-spacing:.18em;color:var(--ac)}
.agent-role{color:var(--gray);font-size:1rem;margin-bottom:.7rem}
.agent-tags{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}
.hero-tag{font-size:.74rem;background:var(--bg-dark);border:1px solid var(--border);
  border-radius:20px;padding:.22rem .7rem;color:var(--gray)}
.agent-bio{font-size:1.05rem;line-height:1.6;color:var(--gray-light);max-width:70ch;margin:0 0 1.4rem}
.agent-spec{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.7rem}
.agent-spec>div{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:.7rem .9rem}
.spec-l{display:block;font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;color:var(--gray);margin-bottom:.25rem}
.spec-v{font-weight:600;color:var(--white);font-size:.92rem}

/* job table */
.job-table{width:100%;border-collapse:collapse;font-size:.86rem}
.job-table th{text-align:left;padding:.55rem .7rem;border-bottom:2px solid var(--border);
  font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:var(--gray)}
.job-table td{padding:.55rem .7rem;border-bottom:1px solid var(--border);vertical-align:top}
.job-table tr.row-off td{opacity:.55}
.mono{font-family:ui-monospace,Menlo,monospace;font-size:.82em;color:var(--gray-light)}
.tag-badge{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;
  padding:.16rem .5rem;border-radius:4px;display:inline-block}
.badge-ok{background:rgba(46,158,91,.16);color:#2E9E5B}
.badge-warn{background:rgba(224,161,0,.18);color:#E0A100}
.badge-off{background:var(--border);color:var(--gray)}
.err-count{color:#C0392B;font-weight:700;font-size:.78rem}

/* mini roster */
.mini-roster{display:flex;flex-wrap:wrap;gap:.6rem}
.mini-agent{display:inline-flex;transition:var(--transition)}
.mini-agent:hover{transform:translateY(-3px)}

/* cowork */
.cowork-group{margin-bottom:1.8rem;border-left:3px solid var(--ac);padding-left:1rem}
.cowork-group-head{display:flex;align-items:center;gap:.7rem;text-decoration:none;color:inherit;margin-bottom:.8rem}
.cowork-group-head:hover .cowork-group-name{color:var(--ac)}
.cowork-group-name{font-family:var(--font-main);font-weight:700;font-size:1.15rem;color:var(--white)}
.cowork-group-meta{font-size:.78rem;color:var(--gray)}
.cowork-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:.8rem}
.cowork-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);
  padding:1rem 1.1rem;transition:var(--transition);position:relative}
.cowork-card:hover{border-color:var(--gold);transform:translateY(-2px)}
.cowork-dot{width:8px;height:8px;border-radius:50%;background:var(--gold);margin-bottom:.6rem}
.cowork-name{font-family:var(--font-main);font-weight:700;color:var(--white);font-size:1rem;margin-bottom:.3rem}
.cowork-slug{font-size:.74rem;color:var(--gray);word-break:break-all}

@media(max-width:760px){
  .split{grid-template-columns:1fr}
  .feed-agent{min-width:90px}
}
