/* Skunkbox — Railway-grade dark control plane.
   Palette studied live from railway.com/dashboard (2026-06-09). */
:root{
  --bg:#0B0A0F;            /* near-black, slightly warm */
  --bg-grid:#15131C;
  --panel:#141119;
  --card:#17141F;
  --card-hover:#1E1A29;
  --line:#272232;
  --line-soft:#1d1926;
  --text:#EDEAF2;
  --text-dim:#8A8397;
  --text-faint:#5C5668;
  --accent:#A855F7;        /* skunkbox purple (Railway-ish) */
  --accent-soft:#7C3AED;
  --green:#3FB950;
  --amber:#D29922;
  --red:#F85149;
  --radius:12px;
  --radius-sm:8px;
  --sans:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --mono:'JetBrains Mono','SF Mono',ui-monospace,monospace;
}
*{margin:0;padding:0;box-sizing:border-box}
html,body{height:100%}
body{
  background:var(--bg);
  color:var(--text);
  font-family:var(--sans);
  font-size:14px;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}

/* ---- top bar ---- */
.topbar{
  height:52px;display:flex;align-items:center;gap:14px;
  padding:0 18px;border-bottom:1px solid var(--line);
  background:rgba(11,10,15,.85);backdrop-filter:blur(8px);
  position:sticky;top:0;z-index:20;
}
.brand{display:flex;align-items:center;gap:9px;font-weight:700;letter-spacing:-.01em}
.brand img{width:26px;height:26px;border-radius:7px}
.brand .name{font-size:15px}
.brand .name b{color:var(--accent)}
.env{
  margin-left:6px;font-size:12px;color:var(--text-dim);
  border:1px solid var(--line);border-radius:999px;padding:3px 10px;
}
.spacer{flex:1}
.topbtn{
  display:flex;align-items:center;gap:7px;font-size:13px;color:var(--text-dim);
  background:transparent;border:1px solid var(--line);border-radius:var(--radius-sm);
  padding:6px 12px;transition:.15s;
}
.topbtn:hover{color:var(--text);border-color:var(--accent);background:var(--card)}
.topbtn.agent{color:var(--text);border-color:var(--accent-soft);background:rgba(168,85,247,.08)}
.topbtn.agent .dot{width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 8px var(--accent)}

/* ---- layout ---- */
.shell{display:flex;min-height:calc(100vh - 52px)}
.rail{
  width:54px;flex-shrink:0;border-right:1px solid var(--line);
  display:flex;flex-direction:column;align-items:center;gap:6px;padding:14px 0;
}
.rail .ico{
  width:36px;height:36px;border-radius:9px;display:grid;place-items:center;
  color:var(--text-faint);font-size:17px;transition:.15s;
}
.rail .ico:hover{background:var(--card);color:var(--text)}
.rail .ico.on{background:rgba(168,85,247,.12);color:var(--accent)}

.main{
  flex:1;padding:26px 30px 60px;
  background-image:radial-gradient(circle at 1px 1px, var(--bg-grid) 1px, transparent 0);
  background-size:22px 22px;
}
.main h1{font-size:19px;font-weight:650;letter-spacing:-.02em;margin-bottom:3px}
.main .sub{color:var(--text-dim);font-size:13px;margin-bottom:24px}

/* ---- project section ---- */
.project{margin-bottom:30px}
.project-head{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.project-head .pname{font-size:14px;font-weight:600;letter-spacing:-.01em}
.project-head .count{font-size:12px;color:var(--text-dim);
  border:1px solid var(--line);border-radius:999px;padding:2px 9px}
.project-head .bar{flex:1;height:1px;background:var(--line-soft)}
.project.system .pname{color:var(--text-faint)}

.grid{
  display:grid;gap:13px;
  grid-template-columns:repeat(auto-fill,minmax(258px,1fr));
}

/* ---- service card ---- */
.card{
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:15px 16px;transition:.15s;cursor:pointer;position:relative;overflow:hidden;
}
.card:hover{background:var(--card-hover);border-color:#352c44;transform:translateY(-1px)}
.card .row1{display:flex;align-items:center;gap:10px}
.card .badge{
  width:30px;height:30px;border-radius:8px;flex-shrink:0;display:grid;place-items:center;
  background:var(--panel);border:1px solid var(--line);font-size:14px;
}
.card .cname{font-weight:600;font-size:14px;letter-spacing:-.01em;flex:1;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.card .domain{color:var(--text-dim);font-size:12px;margin-top:9px;
  font-family:var(--mono);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.card .domain.none{color:var(--text-faint);font-style:italic;font-family:var(--sans)}
.card .status{display:flex;align-items:center;gap:7px;margin-top:11px;font-size:12.5px;color:var(--text-dim)}
.card .sdot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.sdot.running{background:var(--green);box-shadow:0 0 7px rgba(63,185,80,.6)}
.sdot.exited{background:var(--red)}
.sdot.restarting{background:var(--amber)}
.sdot.created,.sdot.paused{background:var(--text-faint)}
.card .metrics{display:flex;gap:14px;margin-top:11px;font-size:11.5px;color:var(--text-faint);font-family:var(--mono)}
.card .typetag{position:absolute;top:13px;right:14px;font-size:10px;letter-spacing:.06em;
  text-transform:uppercase;color:var(--text-faint)}

.empty{color:var(--text-dim);text-align:center;padding:60px;border:1px dashed var(--line);border-radius:var(--radius)}
.err{color:var(--red);background:rgba(248,81,73,.08);border:1px solid rgba(248,81,73,.3);
  border-radius:var(--radius-sm);padding:12px 14px;margin-bottom:18px;font-family:var(--mono);font-size:12.5px}

/* ---- Agent panel (Wren) ---- */
.agent-panel{
  position:fixed;top:0;right:0;height:100vh;width:420px;max-width:92vw;z-index:40;
  background:var(--panel);border-left:1px solid var(--line);
  display:flex;flex-direction:column;transform:translateX(100%);transition:transform .18s ease;
  box-shadow:-20px 0 40px rgba(0,0,0,.35);
}
.agent-panel.open{transform:translateX(0)}
.agent-head{display:flex;align-items:center;justify-content:space-between;
  padding:14px 16px;border-bottom:1px solid var(--line)}
.agent-title{display:flex;align-items:center;gap:8px;font-weight:600;font-size:13.5px}
.agent-title .dot{width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 8px var(--accent)}
.agent-x{background:none;border:none;color:var(--text-dim);font-size:15px}
.agent-x:hover{color:var(--text)}
.agent-log{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px}
.agent-hint{color:var(--text-faint);font-size:12.5px;line-height:1.6;font-style:italic}
.msg{font-size:13.5px;line-height:1.55;white-space:pre-wrap;word-break:break-word}
.msg.user{align-self:flex-end;background:rgba(168,85,247,.12);border:1px solid var(--accent-soft);
  border-radius:10px 10px 2px 10px;padding:9px 12px;max-width:88%}
.msg.wren{align-self:flex-start;color:var(--text);max-width:96%}
.msg.tool{align-self:flex-start;font-family:var(--mono);font-size:11.5px;color:var(--text-dim);
  background:var(--card);border:1px solid var(--line);border-radius:8px;padding:7px 10px;max-width:96%}
.msg.tool .tn{color:var(--accent-bright)}
.msg.err{align-self:flex-start;color:var(--red);font-size:12.5px;font-family:var(--mono)}
.agent-input{display:flex;gap:8px;padding:12px;border-top:1px solid var(--line)}
.agent-input textarea{flex:1;resize:none;max-height:120px;padding:9px 11px;font-size:13.5px;
  font-family:var(--sans);color:var(--text);background:var(--card);border:1px solid var(--line);
  border-radius:8px;outline:none}
.agent-input textarea:focus{border-color:var(--accent)}
.agent-input button{width:40px;border:none;border-radius:8px;background:var(--accent-soft);color:#fff;font-size:14px}
.agent-input button:hover{background:var(--accent)}
.agent-input button:disabled{opacity:.4;cursor:default}

/* ---- Terminal drawer ---- */
.term-drawer{position:fixed;left:0;right:0;bottom:0;height:44vh;z-index:45;
  background:#0A0910;border-top:1px solid var(--line);display:flex;flex-direction:column;
  transform:translateY(100%);transition:transform .18s ease;box-shadow:0 -22px 44px rgba(0,0,0,.45)}
.term-drawer.open{transform:translateY(0)}
.term-head{display:flex;align-items:center;gap:11px;padding:8px 14px;border-bottom:1px solid var(--line)}
.term-title{font-weight:600;font-size:12.5px}
.term-meta{font-family:var(--mono);font-size:11px;color:var(--text-faint)}
.term-meta.live{color:var(--green)}
.term-x{background:none;border:none;color:var(--text-dim);font-size:14px}
.term-x:hover{color:var(--text)}
.term-body{flex:1;padding:6px 8px 4px;overflow:hidden}
.term-body .xterm{height:100%}
