/* ═══════════════════════════════════════════════════════════════════
   HELM — App Stylesheet
   Mobile-first PWA styles. Inherits theme tokens from theme.css.
═══════════════════════════════════════════════════════════════════ */

/* ─────────────────────────────────────────────────────────────────
   ICONS
───────────────────────────────────────────────────────────────── */
.icon { display:inline-block; vertical-align:middle; }
.icon-sm { width:18px; height:18px; }
.icon-tab { width:20px; height:20px; }

/* ─────────────────────────────────────────────────────────────────
   MATRIX CANVAS
───────────────────────────────────────────────────────────────── */
#matrix-canvas {
  position:fixed; top:0; left:0; width:100%; height:100%;
  pointer-events:none; z-index:0; display:none;
}

/* ─────────────────────────────────────────────────────────────────
   APP HEADER
───────────────────────────────────────────────────────────────── */
.app-hdr {
  position:fixed; top:0; left:0; right:0; height:52px;
  background:var(--nav-bg); backdrop-filter:blur(18px);
  border-bottom:var(--border-width) solid var(--border);
  display:flex; align-items:center; justify-content:space-between;
  padding:0 12px; z-index:200; gap:8px;
}
.app-hdr-l, .app-hdr-r { display:flex; align-items:center; gap:8px; }
.app-hdr-menu {
  background:none; border:none; color:var(--text-muted); cursor:pointer;
  padding:6px; display:none; /* hidden on desktop, shown on mobile */
}
.app-brand {
  display:flex; align-items:center; gap:8px;
  text-decoration:none; color:var(--accent);
}
.app-logo-svg { width:24px; height:24px; }
.app-brand-text {
  font-family:var(--font-d); font-size:.9rem; font-weight:700;
  letter-spacing:.14em; color:var(--accent);
}
.app-sep { width:1px; height:18px; background:var(--border); flex-shrink:0; }
.app-page-title {
  font-family:var(--font-m); font-size:.72rem; letter-spacing:.1em;
  color:var(--text-muted); text-transform:uppercase;
}
.app-hdr-btn {
  background:none; border:var(--border-width) solid var(--border);
  color:var(--text-muted); cursor:pointer; padding:5px 8px;
  font-family:var(--font-m); font-size:.55rem; letter-spacing:.1em;
  transition:color .2s, border-color .2s;
}
.app-hdr-btn:hover, .app-hdr-btn.active { color:var(--accent); border-color:var(--accent); }
.app-bell { position:relative; }
.app-bell-badge {
  position:absolute; top:-4px; right:-4px;
  background:#ef4444; color:#fff; font-size:.5rem;
  font-family:var(--font-m); min-width:14px; height:14px;
  border-radius:7px; display:flex; align-items:center; justify-content:center;
  padding:0 3px;
}

/* ── Bell Dropdown ── */
.bell-dropdown {
  position:absolute; top:100%; right:0; z-index:220;
  width:320px; max-height:420px; overflow:hidden;
  background:var(--panel-bg); border:1px solid var(--border);
  border-radius:var(--radius); box-shadow:0 8px 24px rgba(0,0,0,.4);
  display:flex; flex-direction:column;
  opacity:0; pointer-events:none; transform:translateY(-8px);
  transition:opacity .2s ease, transform .2s ease;
}
.bell-dropdown.open { opacity:1; pointer-events:auto; transform:translateY(0); }
.bell-dropdown-hdr {
  display:flex; justify-content:space-between; align-items:center;
  padding:10px 14px; border-bottom:1px solid var(--border);
}
.bell-dropdown-title { font-family:var(--font-h); font-size:.82rem; font-weight:700; color:var(--text); }
.bell-dropdown-mark {
  background:none; border:none; color:var(--accent); cursor:pointer;
  font-size:.68rem; font-family:var(--font-m); padding:0;
}
.bell-dropdown-mark:hover { text-decoration:underline; }
.bell-dropdown-list { flex:1; overflow-y:auto; }
.bell-dropdown-item {
  display:flex; align-items:flex-start; gap:10px; padding:10px 14px;
  border-bottom:1px solid var(--border); cursor:pointer;
  transition:background .15s;
}
.bell-dropdown-item:last-child { border-bottom:none; }
.bell-dropdown-item:hover { background:var(--bg-alt); }
.bell-dropdown-item.unread { background:rgba(99,102,241,.06); }
.bell-item-icon { flex-shrink:0; margin-top:2px; }
.bell-item-body { flex:1; min-width:0; }
.bell-item-title { display:block; font-size:.75rem; font-weight:600; color:var(--text); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.bell-item-msg { display:block; font-size:.68rem; color:var(--text-muted); margin-top:1px; line-height:1.3; }
.bell-item-time { flex-shrink:0; font-size:.6rem; color:var(--text-dim, var(--text-muted)); font-family:var(--font-m); margin-top:2px; }
.bell-dropdown-empty { padding:24px 14px; text-align:center; color:var(--text-muted); font-size:.78rem; }
.bell-dropdown-footer {
  display:block; text-align:center; padding:10px; border-top:1px solid var(--border);
  font-size:.72rem; color:var(--accent); text-decoration:none; font-family:var(--font-m);
}
.bell-dropdown-footer:hover { background:var(--bg-alt); }

/* ─────────────────────────────────────────────────────────────────
   HUD PANEL (Theme + Font picker dropdown)
───────────────────────────────────────────────────────────────── */
.app-hud-panel {
  position:fixed; top:52px; right:0; z-index:210;
  background:var(--nav-bg); border:1px solid var(--border); border-top:none;
  backdrop-filter:blur(18px); padding:10px 14px;
  display:flex; flex-direction:column; gap:8px;
  transform:translateY(-100%); opacity:0; pointer-events:none;
  transition:transform .25s ease, opacity .2s ease;
}
.app-hud-panel.open { transform:translateY(0); opacity:1; pointer-events:auto; }
.hud-row { display:flex; align-items:center; gap:5px; }
.hud-row-sep { height:1px; background:var(--border); }
.dock-lbl { font-family:var(--font-m); font-size:.55rem; letter-spacing:.14em; color:var(--text-muted); margin-right:2px; padding-right:6px; }

/* Theme dots */
.db {
  width:18px; height:18px; border-radius:50%; border:2px solid transparent;
  cursor:pointer; flex-shrink:0; transition:border-color .15s, transform .15s;
}
.db:hover { transform:scale(1.2); }
.db.active { border-color:var(--accent); transform:scale(1.15); }
.d-sp { background:#888; }
.d-iv { background:#f0f0f0; }
.d-nv { background:#00e5ff; }
.d-sl { background:#ff8c00; }
.d-mx { background:#00ff41; }
.d-rt { background:#e86c3a; }
.d-lc { background:#ff9966; }
.d-px { background:#ffff00; }

/* Font buttons */
.fb {
  width:18px; height:18px;
  border:1px solid var(--border); background:transparent;
  color:var(--text-muted); cursor:pointer; flex-shrink:0;
  display:flex; align-items:center; justify-content:center;
  font-size:9px; transition:border-color .15s, color .15s;
}
.fb:hover { border-color:var(--border-hi); color:var(--text); }
.fb.active { border-color:var(--accent); color:var(--accent); }
.fb-auto  { font-family:var(--font-m); font-size:10px; }
.fb-clean { font-family:'Inter', sans-serif; font-size:11px; font-weight:600; }
.fb-space { font-family:'Orbitron', sans-serif; font-size:7px; font-weight:700; }
.fb-tac   { font-family:'Rajdhani', sans-serif; font-size:12px; font-weight:700; }
.fb-code  { font-family:'Fira Code', monospace; font-size:9px; }
.fb-serif { font-family:'Playfair Display', serif; font-size:11px; font-style:italic; }
.fb-mono  { font-family:'Share Tech Mono', monospace; font-size:10px; }
.fb-pixel { font-family:'Press Start 2P', monospace; font-size:5px; }

/* ─────────────────────────────────────────────────────────────────
   SIDEBAR (Desktop always visible, mobile drawer)
───────────────────────────────────────────────────────────────── */
.app-sidebar {
  position:fixed; top:52px; left:0; bottom:0; width:220px;
  background:var(--nav-bg); backdrop-filter:blur(18px);
  border-right:var(--border-width) solid var(--border);
  display:flex; flex-direction:column; justify-content:space-between;
  overflow-y:auto; z-index:190;
  transition:transform .3s ease;
}
.app-sidebar-overlay {
  display:none; position:fixed; inset:0; z-index:189;
  background:rgba(0,0,0,.5);
}
.app-side-nav { display:flex; flex-direction:column; padding:8px; gap:2px; }
.side-link {
  display:flex; align-items:center; gap:10px; padding:10px 12px;
  color:var(--text-muted); text-decoration:none; font-family:var(--font-b);
  font-size:.78rem; border-radius:var(--radius);
  transition:background .15s, color .15s;
}
.side-link:hover { background:var(--surface); color:var(--text); }
.side-link.active { background:var(--surface2); color:var(--accent); }
.side-link.active svg { color:var(--accent); }
.side-divider { height:1px; background:var(--border); margin:6px 12px; }
.side-footer {
  padding:12px 16px; border-top:var(--border-width) solid var(--border);
}
.side-ver {
  font-family:var(--font-m); font-size:.56rem; letter-spacing:.12em;
  color:var(--text-dim);
}

/* ─────────────────────────────────────────────────────────────────
   MAIN CONTENT
───────────────────────────────────────────────────────────────── */
.app-main {
  margin-top:52px; margin-left:220px;
  min-height:calc(100vh - 52px);
  padding:20px; overflow-y:auto;
  position:relative; z-index:1;
}

/* ─────────────────────────────────────────────────────────────────
   BOTTOM TAB BAR (Mobile only)
───────────────────────────────────────────────────────────────── */
.app-tabbar {
  display:none; /* shown via media query on mobile */
  position:fixed; bottom:0; left:0; right:0;
  height:60px; background:var(--nav-bg); backdrop-filter:blur(18px);
  border-top:var(--border-width) solid var(--border);
  z-index:200; padding-bottom:env(safe-area-inset-bottom, 0);
}
.tab {
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:3px; text-decoration:none; color:var(--text-muted);
  font-family:var(--font-m); font-size:.5rem; letter-spacing:.08em;
  text-transform:uppercase; padding:6px 0;
  transition:color .15s;
}
.tab.active { color:var(--accent); }
.tab.active svg { color:var(--accent); }
.tab:hover { color:var(--text); }

/* ─────────────────────────────────────────────────────────────────
   EMPTY STATE
───────────────────────────────────────────────────────────────── */
.app-empty {
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  text-align:center; padding:80px 24px; gap:14px; min-height:60vh;
}
.app-empty-icon { width:64px; height:64px; opacity:.2; color:var(--accent); }
.app-empty h2 { font-family:var(--font-d); font-size:1.15rem; color:var(--text); margin:0; }
.app-empty p { color:var(--text-muted); font-size:.82rem; margin:0; max-width:320px; line-height:1.65; }
.app-empty-acts { display:flex; gap:10px; flex-wrap:wrap; justify-content:center; margin-top:6px; }

/* ─────────────────────────────────────────────────────────────────
   BUTTONS
───────────────────────────────────────────────────────────────── */
.btn {
  display:inline-flex; align-items:center; gap:6px;
  padding:8px 16px; border:var(--border-width) solid var(--border);
  background:transparent; color:var(--text); text-decoration:none;
  font-family:var(--font-m); font-size:.72rem; letter-spacing:.08em;
  cursor:pointer; transition:border-color .2s, color .2s, box-shadow .2s;
}
.btn:hover { border-color:var(--border-hi); box-shadow:var(--glow); }
.btn-sm { font-size:.62rem; padding:5px 12px; }
.btn-primary {
  background:var(--accent); color:var(--bg); border-color:var(--accent);
}
.btn-primary:hover { box-shadow:var(--glow-hi); }

/* Highlight text */
.hl { color:var(--accent); }
.mono { font-family:var(--font-m); }

/* ─────────────────────────────────────────────────────────────────
   STATUS DOTS (reused from main site)
───────────────────────────────────────────────────────────────── */
.status-dot { display:inline-block; width:8px; height:8px; border-radius:50%; flex-shrink:0; }
.dot-g { background:#22c55e; }
.dot-r { background:#ef4444; }
.dot-a { background:#f59e0b; }
.dot-pulse { animation:dpulse 2s ease-in-out infinite; }
@keyframes dpulse { 0%,100%{opacity:1} 50%{opacity:.3} }

/* ─────────────────────────────────────────────────────────────────
   HOME VIEW
───────────────────────────────────────────────────────────────── */
.home-wrap { max-width:900px; margin:0 auto; display:flex; flex-direction:column; gap:28px; }
.home-greeting { }
.home-hello { font-family:var(--font-d); font-size:1.3rem; font-weight:700; line-height:1.4; }
.home-sub { font-family:var(--font-m); font-size:.68rem; letter-spacing:.12em; color:var(--text-muted); margin-top:4px; }

/* Stats Ring Row */
.home-stats {
  display:grid; grid-template-columns:repeat(4, 1fr); gap:14px;
}
.home-stat {
  display:flex; flex-direction:column; align-items:center; gap:8px;
  padding:16px 8px; border:var(--border-width) solid var(--border);
  background:var(--panel-bg); border-radius:var(--radius);
}
.home-stat-ring { position:relative; width:56px; height:56px; }
.ring-svg { width:100%; height:100%; transform:rotate(-90deg); }
.ring-bg { fill:none; stroke:var(--border); stroke-width:4; }
.ring-fill {
  fill:none; stroke:var(--accent); stroke-width:4; stroke-linecap:round;
  stroke-dasharray:113.1; transition:stroke-dashoffset 1.2s ease;
}
.ring-center {
  position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
  font-family:var(--font-d); font-size:.82rem; font-weight:700;
  color:var(--text); pointer-events:none;
}
.home-stat-label {
  font-family:var(--font-m); font-size:.5rem; letter-spacing:.14em;
  color:var(--text-muted); text-transform:uppercase;
}

/* Quick Actions */
.home-section { display:flex; flex-direction:column; gap:12px; }
.home-section-title {
  font-family:var(--font-m); font-size:.62rem; letter-spacing:.16em;
  color:var(--text-muted); text-transform:uppercase;
}
.home-actions {
  display:grid; grid-template-columns:repeat(auto-fill, minmax(140px, 1fr)); gap:10px;
}
.home-action-btn {
  display:flex; align-items:center; gap:8px; padding:12px 14px;
  border:var(--border-width) solid var(--border); background:var(--panel-bg);
  color:var(--text); text-decoration:none; font-family:var(--font-b);
  font-size:.78rem; border-radius:var(--radius);
  transition:border-color .2s, box-shadow .2s, transform .15s;
}
.home-action-btn:hover { border-color:var(--border-hi); box-shadow:var(--glow); transform:translateY(-2px); }
.home-action-btn svg { color:var(--accent); flex-shrink:0; }
.home-action-btn.primary {
  background:var(--accent); color:var(--bg); border-color:var(--accent);
}
.home-action-btn.primary svg { color:var(--bg); }

/* System Status */
.home-status-grid {
  display:grid; grid-template-columns:repeat(auto-fill, minmax(200px, 1fr)); gap:10px;
}
.home-status-card {
  display:flex; align-items:center; gap:10px; padding:12px 14px;
  border:var(--border-width) solid var(--border); background:var(--panel-bg);
  border-radius:var(--radius);
}
.status-label { font-family:var(--font-b); font-size:.78rem; color:var(--text); }
.status-val { font-family:var(--font-m); font-size:.62rem; color:var(--text-muted); margin-top:2px; }

/* Activity Feed */
.home-feed {
  border:var(--border-width) solid var(--border); background:var(--panel-bg);
  border-radius:var(--radius); padding:16px; min-height:80px;
}
.feed-empty { text-align:center; }
.feed-empty p { color:var(--text-dim); font-size:.78rem; }
.feed-item {
  display:flex; align-items:center; gap:10px; padding:8px 0;
  border-bottom:1px solid var(--border);
}
.feed-item:last-child { border-bottom:none; }
.feed-time { font-family:var(--font-m); font-size:.52rem; color:var(--text-dim); flex-shrink:0; min-width:50px; }
.feed-text { font-family:var(--font-b); font-size:.78rem; color:var(--text-muted); }
.feed-text strong { color:var(--text); font-weight:600; }

/* ─────────────────────────────────────────────────────────────────
   AUTH / PROFILE VIEW
───────────────────────────────────────────────────────────────── */
.auth-wrap {
  display:flex; align-items:center; justify-content:center;
  min-height:calc(100vh - 112px); padding:24px;
}
.auth-card {
  width:100%; max-width:380px;
  border:var(--border-width) solid var(--border); background:var(--panel-bg);
  padding:32px 28px; border-radius:var(--radius);
  display:flex; flex-direction:column; align-items:center; gap:16px;
}
.auth-logo { display:flex; align-items:center; justify-content:center; }
.auth-logo-svg { width:48px; height:48px; color:var(--accent); }
.auth-title { font-family:var(--font-d); font-size:1.1rem; font-weight:700; margin:0; }
.auth-sub { font-family:var(--font-m); font-size:.62rem; letter-spacing:.1em; color:var(--text-muted); margin:0; }

.auth-tabs { display:flex; width:100%; border-bottom:var(--border-width) solid var(--border); }
.auth-tab {
  flex:1; padding:10px; background:none; border:none; cursor:pointer;
  font-family:var(--font-m); font-size:.68rem; letter-spacing:.1em;
  color:var(--text-muted); text-transform:uppercase;
  border-bottom:2px solid transparent; transition:color .2s, border-color .2s;
}
.auth-tab:hover { color:var(--text); }
.auth-tab.active { color:var(--accent); border-bottom-color:var(--accent); }

.auth-form { display:flex; flex-direction:column; gap:14px; width:100%; }
.auth-field { display:flex; flex-direction:column; gap:4px; }
.auth-field label {
  font-family:var(--font-m); font-size:.58rem; letter-spacing:.12em;
  color:var(--text-muted); text-transform:uppercase;
}
.auth-field input {
  padding:10px 12px; background:var(--surface); border:var(--border-width) solid var(--border);
  color:var(--text); font-family:var(--font-b); font-size:.82rem;
  border-radius:var(--radius); transition:border-color .2s;
}
.auth-field input:focus { outline:none; border-color:var(--accent); }
.auth-field input::placeholder { color:var(--text-dim); }

.auth-error { font-family:var(--font-m); font-size:.68rem; color:#ef4444; min-height:18px; }
.auth-submit {
  padding:12px; background:var(--accent); color:var(--bg); border:none;
  font-family:var(--font-d); font-size:.78rem; font-weight:700; letter-spacing:.08em;
  cursor:pointer; transition:opacity .2s; border-radius:var(--radius);
}
.auth-submit:hover { opacity:.9; }
.auth-submit:disabled { opacity:.5; cursor:not-allowed; }

.auth-footer {
  font-family:var(--font-m); font-size:.5rem; letter-spacing:.14em;
  color:var(--text-dim); text-align:center; margin-top:8px;
}

/* Profile (logged in) */
.profile-wrap { max-width:500px; margin:0 auto; display:flex; flex-direction:column; gap:20px; }
.profile-card {
  display:flex; flex-direction:column; align-items:center; gap:12px;
  padding:28px; border:var(--border-width) solid var(--border);
  background:var(--panel-bg); border-radius:var(--radius);
}
.profile-avatar {
  width:64px; height:64px; border-radius:50%;
  background:var(--accent); color:var(--bg);
  display:flex; align-items:center; justify-content:center;
  font-family:var(--font-d); font-size:1.2rem; font-weight:700;
}
.profile-name { font-family:var(--font-d); font-size:1.1rem; font-weight:700; margin:0; }
.profile-email { font-family:var(--font-m); font-size:.72rem; color:var(--text-muted); margin:0; }
.profile-badge {
  font-family:var(--font-m); font-size:.5rem; letter-spacing:.14em;
  padding:3px 10px; border:var(--border-width) solid var(--accent);
  color:var(--accent);
}

.profile-section {
  display:flex; flex-direction:column; gap:10px;
  border:var(--border-width) solid var(--border); background:var(--panel-bg);
  padding:18px; border-radius:var(--radius);
}
.profile-section-title {
  font-family:var(--font-m); font-size:.62rem; letter-spacing:.14em;
  color:var(--text-muted); text-transform:uppercase; margin-bottom:4px;
}
.profile-row {
  display:flex; justify-content:space-between; align-items:center;
  padding:8px 0; border-bottom:1px solid var(--border);
}
.profile-row:last-child { border-bottom:none; }
.profile-row-label { font-size:.8rem; color:var(--text); }
.profile-row-val { font-family:var(--font-m); font-size:.72rem; color:var(--text-muted); }
.profile-action-btn {
  display:flex; align-items:center; gap:8px;
  padding:10px 14px; background:none; border:var(--border-width) solid var(--border);
  color:var(--text-muted); font-family:var(--font-b); font-size:.78rem;
  cursor:pointer; border-radius:var(--radius); transition:color .2s, border-color .2s;
}
.profile-action-btn:hover { color:#ef4444; border-color:#ef4444; }

/* ─────────────────────────────────────────────────────────────────
   MODAL
───────────────────────────────────────────────────────────────── */
.modal-overlay {
  position:fixed; inset:0; z-index:300;
  background:rgba(0,0,0,.6); backdrop-filter:blur(4px);
  display:none; align-items:center; justify-content:center; padding:24px;
}
.modal-overlay.open { display:flex; }
.modal-box {
  background:var(--panel-bg); border:var(--border-width) solid var(--border);
  width:100%; max-width:440px; border-radius:var(--radius);
}
.modal-hdr {
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 18px; border-bottom:var(--border-width) solid var(--border);
}
.modal-title { font-family:var(--font-d); font-size:.88rem; font-weight:700; margin:0; }
.modal-close {
  background:none; border:none; color:var(--text-muted); cursor:pointer;
  padding:4px; transition:color .2s;
}
.modal-close:hover { color:var(--accent); }
.modal-body { padding:18px; }

/* ─────────────────────────────────────────────────────────────────
   MOBILE RESPONSIVE
───────────────────────────────────────────────────────────────── */
@media (max-width:768px) {
  /* Show mobile menu button */
  .app-hdr-menu { display:flex; }

  /* Sidebar becomes drawer */
  .app-sidebar { transform:translateX(-100%); }
  .app-sidebar.open { transform:translateX(0); }
  .app-sidebar-overlay.open { display:block; }

  /* Main fills full width */
  .app-main { margin-left:0; padding:16px; padding-bottom:80px; }

  /* Show tab bar */
  .app-tabbar {
    display:flex; align-items:stretch; justify-content:space-around;
  }

  /* Responsive grids */
  .home-stats { grid-template-columns:repeat(2, 1fr); }
  .home-actions { grid-template-columns:repeat(2, 1fr); }
  .home-status-grid { grid-template-columns:1fr; }
}

@media (max-width:480px) {
  .home-stats { grid-template-columns:repeat(2, 1fr); gap:8px; }
  .home-actions { grid-template-columns:1fr; }
  .home-hello { font-size:1.05rem; }
  .app-brand-text { display:none; }
}

/* ─────────────────────────────────────────────────────────────────
   SHARED VIEW COMPONENTS
───────────────────────────────────────────────────────────────── */

/* View Topbar */
.view-topbar {
  display:flex; align-items:center; justify-content:space-between;
  gap:12px; margin-bottom:20px; flex-wrap:wrap;
}
.view-topbar-l { display:flex; align-items:center; gap:8px; flex-wrap:wrap; }
.search-box {
  display:flex; align-items:center; gap:6px;
  padding:6px 10px; border:var(--border-width) solid var(--border);
  background:var(--surface); border-radius:var(--radius);
}
.search-input {
  background:none; border:none; color:var(--text); font-family:var(--font-b);
  font-size:.78rem; outline:none; width:160px;
}
.search-input::placeholder { color:var(--text-dim); }
.filter-select {
  padding:6px 10px; background:var(--surface); border:var(--border-width) solid var(--border);
  color:var(--text); font-family:var(--font-m); font-size:.68rem;
  letter-spacing:.06em; border-radius:var(--radius); cursor:pointer;
}
.filter-select option { background:var(--bg); color:var(--text); }

/* Loading / Error */
.loading-state, .error-state { padding:40px; text-align:center; }
.loading-state p, .error-state p { color:var(--text-muted); font-size:.82rem; }
.text-muted { color:var(--text-muted); }
.text-sm { font-size:.78rem; }

/* Detail Layout */
.detail-wrap { max-width:800px; margin:0 auto; display:flex; flex-direction:column; gap:20px; }
.detail-back { display:flex; align-items:center; justify-content:space-between; gap:10px; }
.detail-header { display:flex; align-items:center; gap:16px; padding:20px; border:var(--border-width) solid var(--border); background:var(--panel-bg); border-radius:var(--radius); }
.detail-header-info { flex:1; }
.detail-header-icon-lg { width:48px; height:48px; color:var(--accent); }
.detail-name { font-family:var(--font-d); font-size:1.2rem; font-weight:700; margin:0; }
.detail-meta-row { display:flex; align-items:center; gap:8px; margin-top:4px; flex-wrap:wrap; }
.detail-status { font-family:var(--font-m); font-size:.68rem; letter-spacing:.1em; text-transform:capitalize; color:var(--text-muted); }
.detail-section { border:var(--border-width) solid var(--border); background:var(--panel-bg); border-radius:var(--radius); padding:18px; }
.detail-section-title { font-family:var(--font-m); font-size:.62rem; letter-spacing:.14em; text-transform:uppercase; color:var(--text-muted); margin:0 0 12px 0; }
.detail-grid { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.detail-kv { display:flex; flex-direction:column; gap:8px; }
.detail-kv-row { display:flex; justify-content:space-between; align-items:center; padding:8px 0; border-bottom:1px solid var(--border); }
.detail-kv-row:last-child { border-bottom:none; }
.kv-label { font-family:var(--font-b); font-size:.78rem; color:var(--text-muted); }
.kv-val { font-family:var(--font-b); font-size:.78rem; color:var(--text); }

/* ─────────────────────────────────────────────────────────────────
   AGENTS VIEW
───────────────────────────────────────────────────────────────── */
.agents-wrap { max-width:900px; margin:0 auto; }
.agents-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(280px, 1fr)); gap:14px; }
.agent-card {
  display:flex; flex-direction:column; gap:10px;
  padding:16px; border:var(--border-width) solid var(--border);
  background:var(--panel-bg); border-radius:var(--radius);
  cursor:pointer; transition:border-color .2s, box-shadow .2s, transform .15s;
}
.agent-card:hover { border-color:var(--border-hi); box-shadow:var(--glow); transform:translateY(-2px); }
.agent-card-hdr { display:flex; align-items:center; gap:10px; }
.agent-avatar {
  width:36px; height:36px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-family:var(--font-d); font-size:.7rem; font-weight:700;
  color:#fff; flex-shrink:0;
}
.agent-avatar-lg { width:52px; height:52px; font-size:.95rem; }
.agent-card-info { flex:1; min-width:0; }
.agent-card-name { font-family:var(--font-d); font-size:.88rem; font-weight:700; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.agent-card-role { font-family:var(--font-m); font-size:.56rem; letter-spacing:.12em; color:var(--text-muted); text-transform:uppercase; }
.agent-card-meta { display:flex; gap:6px; flex-wrap:wrap; }
.agent-tag {
  font-family:var(--font-m); font-size:.52rem; letter-spacing:.08em;
  padding:2px 8px; border:1px solid var(--border); color:var(--text-muted);
  text-transform:capitalize;
}
.status-tag-active { border-color:#22c55e; color:#22c55e; }
.status-tag-idle { border-color:#f59e0b; color:#f59e0b; }
.status-tag-paused { border-color:var(--text-dim); color:var(--text-dim); }
.status-tag-error { border-color:#ef4444; color:#ef4444; }
.status-tag-deployed { border-color:#22c55e; color:#22c55e; }
.status-tag-standby { border-color:#f59e0b; color:#f59e0b; }
.agent-card-tools { display:flex; gap:4px; flex-wrap:wrap; }
.agent-tool-tag {
  font-family:var(--font-m); font-size:.48rem; letter-spacing:.06em;
  padding:2px 6px; background:var(--surface); color:var(--text-dim);
  border-radius:2px;
}
.agent-tools-list { display:flex; gap:6px; flex-wrap:wrap; }
.agent-card-actions { display:flex; gap:6px; padding-top:6px; border-top:1px solid var(--border); }
.agent-action-btn {
  font-family:var(--font-m); font-size:.56rem; letter-spacing:.08em;
  padding:4px 10px; background:none; border:1px solid var(--border);
  color:var(--text-muted); cursor:pointer; transition:color .2s, border-color .2s;
}
.agent-action-btn:hover { color:var(--accent); border-color:var(--accent); }
.agent-delete-btn:hover { color:#ef4444; border-color:#ef4444; }
.agent-toggle-btn { text-transform:uppercase; }

/* ─────────────────────────────────────────────────────────────────
   BUILDER VIEW
───────────────────────────────────────────────────────────────── */
.builder-wrap { max-width:680px; margin:0 auto; display:flex; flex-direction:column; gap:20px; }
.builder-header { display:flex; align-items:center; gap:14px; }
.builder-header-icon { width:40px; height:40px; color:var(--accent); flex-shrink:0; }
.builder-title { font-family:var(--font-d); font-size:1.1rem; font-weight:700; margin:0; }
.builder-sub { font-family:var(--font-m); font-size:.62rem; letter-spacing:.1em; color:var(--text-muted); margin:2px 0 0 0; }
.builder-form { display:flex; flex-direction:column; gap:18px; }
.builder-section {
  border:var(--border-width) solid var(--border); background:var(--panel-bg);
  border-radius:var(--radius); padding:18px; margin:0;
}
.builder-legend {
  font-family:var(--font-m); font-size:.62rem; letter-spacing:.14em;
  text-transform:uppercase; color:var(--accent); padding:0 6px;
}
.builder-row { display:grid; grid-template-columns:repeat(auto-fit, minmax(160px, 1fr)); gap:14px; }
.builder-select { width:100%; padding:10px 12px; }
.builder-range { width:100%; accent-color:var(--accent); }
.builder-range-val {
  font-family:var(--font-m); font-size:.72rem; color:var(--accent);
  display:inline-block; min-width:28px; text-align:center;
}
.builder-hint { font-family:var(--font-m); font-size:.62rem; color:var(--text-dim); margin:0 0 10px 0; }
.builder-actions { display:flex; align-items:center; gap:12px; }
.builder-actions .auth-error { flex:1; margin:0; }

/* Memory toggle */
.builder-toggle-field { display:flex; flex-direction:column; gap:6px; }
.builder-toggle {
  display:flex; align-items:center; gap:8px;
  background:var(--surface); border:var(--border-width) solid var(--border);
  padding:6px 12px; cursor:pointer; border-radius:var(--radius);
  transition:border-color .2s;
}
.builder-toggle.on { border-color:var(--accent); }
.builder-toggle-knob {
  width:14px; height:14px; border-radius:50%; border:2px solid var(--text-dim);
  transition:border-color .2s, background .2s;
}
.builder-toggle.on .builder-toggle-knob { border-color:var(--accent); background:var(--accent); }
.builder-toggle-label { font-family:var(--font-m); font-size:.62rem; letter-spacing:.1em; color:var(--text-muted); }

/* Tool chips */
.builder-tools-grid { display:flex; flex-wrap:wrap; gap:8px; }
.builder-tool-chip {
  display:flex; align-items:center; gap:6px;
  padding:6px 12px; border:var(--border-width) solid var(--border);
  font-family:var(--font-b); font-size:.72rem; cursor:pointer;
  color:var(--text-muted); transition:border-color .15s, color .15s;
  border-radius:var(--radius);
}
.builder-tool-chip input { display:none; }
.builder-tool-chip:hover { border-color:var(--border-hi); color:var(--text); }
.builder-tool-chip.selected { border-color:var(--accent); color:var(--accent); background:rgba(var(--accent-rgb, 100,100,100),0.08); }

/* ─────────────────────────────────────────────────────────────────
   TASKS VIEW
───────────────────────────────────────────────────────────────── */
.tasks-wrap { max-width:900px; margin:0 auto; }
.task-stats-bar {
  display:flex; gap:14px; flex-wrap:wrap; margin-bottom:16px;
  padding:12px; border:var(--border-width) solid var(--border);
  background:var(--panel-bg); border-radius:var(--radius);
}
.task-stat { display:flex; flex-direction:column; align-items:center; gap:2px; flex:1; min-width:60px; }
.task-stat-num { font-family:var(--font-d); font-size:1.1rem; font-weight:700; }
.task-stat-label { font-family:var(--font-m); font-size:.48rem; letter-spacing:.12em; text-transform:uppercase; color:var(--text-muted); }

.tasks-list { display:flex; flex-direction:column; gap:8px; }
.task-row {
  border:var(--border-width) solid var(--border); background:var(--panel-bg);
  border-radius:var(--radius); padding:14px; display:flex; flex-direction:column; gap:8px;
}
.task-row-main { display:flex; align-items:center; gap:10px; flex-wrap:wrap; }
.task-row-info { flex:1; min-width:0; display:flex; flex-direction:column; gap:2px; }
.task-row-title { font-family:var(--font-b); font-size:.82rem; color:var(--text); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.task-row-agent { font-family:var(--font-m); font-size:.56rem; letter-spacing:.1em; color:var(--text-dim); }
.task-row-time { font-family:var(--font-m); font-size:.56rem; color:var(--text-dim); flex-shrink:0; }

/* Status badges */
.task-status-badge {
  font-family:var(--font-m); font-size:.52rem; letter-spacing:.1em;
  padding:3px 10px; text-transform:uppercase; flex-shrink:0;
}
.badge-queued { border:1px solid #f59e0b; color:#f59e0b; }
.badge-running { border:1px solid var(--accent); color:var(--accent); background:rgba(var(--accent-rgb,100,100,100),0.1); }
.badge-completed { border:1px solid #22c55e; color:#22c55e; }
.badge-failed { border:1px solid #ef4444; color:#ef4444; }

/* Priority tags */
.task-priority-tag {
  font-family:var(--font-m); font-size:.48rem; letter-spacing:.08em;
  padding:2px 8px; text-transform:uppercase; flex-shrink:0;
}
.priority-low { color:var(--text-dim); border:1px solid var(--border); }
.priority-medium { color:#f59e0b; border:1px solid #f59e0b; }
.priority-high { color:#f97316; border:1px solid #f97316; }
.priority-critical { color:#ef4444; border:1px solid #ef4444; }

/* Progress */
.task-progress { height:3px; background:var(--border); border-radius:2px; overflow:hidden; }
.task-progress-bar { height:100%; background:var(--accent); transition:width .3s ease; }

/* Task result */
.task-result { background:var(--surface); padding:8px 10px; border-radius:var(--radius); }
.task-result pre { font-family:var(--font-m); font-size:.68rem; color:var(--text-muted); white-space:pre-wrap; word-break:break-word; margin:0; }

/* Mini task list (used in agent detail) */
.task-mini-list { display:flex; flex-direction:column; gap:6px; }
.task-mini-row { display:flex; align-items:center; gap:8px; padding:6px 0; border-bottom:1px solid var(--border); }
.task-mini-row:last-child { border-bottom:none; }
.task-mini-title { flex:1; font-family:var(--font-b); font-size:.78rem; color:var(--text); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.task-mini-time { font-family:var(--font-m); font-size:.52rem; color:var(--text-dim); flex-shrink:0; }

/* ─────────────────────────────────────────────────────────────────
   FLEET VIEW
───────────────────────────────────────────────────────────────── */
.fleet-wrap { max-width:900px; margin:0 auto; }
.fleet-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(300px, 1fr)); gap:14px; }
.fleet-card {
  display:flex; flex-direction:column; gap:10px;
  padding:16px; border:var(--border-width) solid var(--border);
  background:var(--panel-bg); border-radius:var(--radius);
}
.fleet-card-hdr { display:flex; align-items:center; justify-content:space-between; }
.fleet-card-info { flex:1; }
.fleet-card-name { font-family:var(--font-d); font-size:.92rem; font-weight:700; }
.fleet-card-count { font-family:var(--font-m); font-size:.56rem; letter-spacing:.1em; color:var(--text-muted); margin-top:2px; }
.fleet-status-group { display:flex; align-items:center; gap:6px; }
.fleet-members { display:flex; flex-direction:column; gap:4px; padding:8px 0; border-top:1px solid var(--border); }
.fleet-member { display:flex; align-items:center; gap:8px; padding:4px 0; }
.fleet-member-dot { width:6px; height:6px; }
.fleet-member-name { font-family:var(--font-b); font-size:.78rem; color:var(--text); }
.fleet-member-role { font-family:var(--font-m); font-size:.52rem; color:var(--text-dim); }
.fleet-card-actions { display:flex; gap:6px; padding-top:6px; border-top:1px solid var(--border); }

/* Fleet Detail */
.fleet-detail-actions { display:flex; gap:10px; }
.fleet-member-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(260px, 1fr)); gap:10px; }
.fleet-member-card {
  display:flex; align-items:center; gap:10px; padding:12px;
  border:var(--border-width) solid var(--border); background:var(--surface);
  border-radius:var(--radius); text-decoration:none; color:var(--text);
  transition:border-color .2s;
}
.fleet-member-card:hover { border-color:var(--border-hi); }
.fleet-member-card-info { flex:1; min-width:0; }
.fleet-member-card-name { font-family:var(--font-b); font-size:.78rem; display:block; }
.fleet-member-card-role { font-family:var(--font-m); font-size:.52rem; color:var(--text-dim); display:block; }

/* Fleet agent picker (modal) */
.fleet-agent-picker { display:flex; flex-wrap:wrap; gap:8px; }
.fleet-agent-chip {
  display:flex; align-items:center; gap:6px;
  padding:6px 12px; border:var(--border-width) solid var(--border);
  font-family:var(--font-b); font-size:.72rem; cursor:pointer;
  color:var(--text-muted); transition:border-color .15s;
  border-radius:var(--radius);
}
.fleet-agent-chip input { display:none; }
.fleet-agent-chip:has(input:checked) { border-color:var(--accent); color:var(--accent); }

/* Danger button */
.btn-danger { color:#ef4444; border-color:#ef4444; }
.btn-danger:hover { box-shadow:0 0 10px rgba(239,68,68,.3); }

/* ─────────────────────────────────────────────────────────────────
   BLUEPRINTS VIEW
───────────────────────────────────────────────────────────────── */
.bp-wrap { max-width:960px; margin:0 auto; display:flex; flex-direction:column; gap:20px; }
.bp-header { display:flex; align-items:flex-start; justify-content:space-between; gap:12px; }
.bp-title { font-family:var(--font-d); font-size:1.2rem; font-weight:700; margin:0; }
.bp-sub { font-family:var(--font-m); font-size:.62rem; letter-spacing:.1em; color:var(--text-muted); margin:4px 0 0 0; }

.bp-categories { display:flex; gap:6px; flex-wrap:wrap; }
.bp-cat-btn {
  padding:5px 14px; background:none; border:var(--border-width) solid var(--border);
  color:var(--text-muted); font-family:var(--font-m); font-size:.6rem;
  letter-spacing:.1em; cursor:pointer; transition:color .15s, border-color .15s;
  border-radius:var(--radius);
}
.bp-cat-btn:hover { color:var(--text); border-color:var(--border-hi); }
.bp-cat-btn.active { color:var(--accent); border-color:var(--accent); background:rgba(var(--accent-rgb,100,100,100),0.08); }

.bp-search-row { display:flex; align-items:center; gap:8px; flex-wrap:wrap; }

.bp-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(260px, 1fr)); gap:14px; }
.bp-card {
  display:flex; flex-direction:column;
  border:var(--border-width) solid var(--border); background:var(--panel-bg);
  border-radius:var(--radius); overflow:hidden;
  transition:border-color .2s, box-shadow .2s, transform .15s;
}
.bp-card:hover { border-color:var(--border-hi); box-shadow:var(--glow); transform:translateY(-2px); }
.bp-card-top {
  display:flex; align-items:center; justify-content:space-between;
  padding:12px 14px 0; gap:8px;
}
.bp-card-icon { width:28px; height:28px; color:var(--accent); flex-shrink:0; }
.bp-rarity {
  font-family:var(--font-m); font-size:.48rem; letter-spacing:.12em;
  padding:2px 8px; border:1px solid; text-transform:uppercase;
}
.bp-card-body { padding:10px 14px; flex:1; display:flex; flex-direction:column; gap:4px; }
.bp-card-name { font-family:var(--font-d); font-size:.88rem; font-weight:700; margin:0; }
.bp-card-cat { font-family:var(--font-m); font-size:.5rem; letter-spacing:.12em; color:var(--text-muted); text-transform:uppercase; }
.bp-card-desc { font-family:var(--font-b); font-size:.74rem; color:var(--text-muted); line-height:1.5; margin:4px 0 0 0; }
.bp-card-footer {
  display:flex; align-items:center; justify-content:space-between;
  padding:10px 14px; border-top:1px solid var(--border); gap:8px;
}
.bp-card-stats { display:flex; flex-direction:column; gap:2px; }
.bp-stars { font-size:.72rem; }
.bp-star { color:var(--text-dim); }
.bp-star.filled { color:#f59e0b; }
.bp-star.half { color:#f59e0b; opacity:.6; }
.bp-downloads { font-family:var(--font-m); font-size:.48rem; letter-spacing:.08em; color:var(--text-dim); }

/* ─────────────────────────────────────────────────────────────────
   ANALYTICS VIEW
───────────────────────────────────────────────────────────────── */
.ana-wrap { max-width:960px; margin:0 auto; display:flex; flex-direction:column; gap:20px; }
.ana-header { display:flex; align-items:flex-start; justify-content:space-between; gap:12px; flex-wrap:wrap; }
.ana-title { font-family:var(--font-d); font-size:1.2rem; font-weight:700; margin:0; }
.ana-sub { font-family:var(--font-m); font-size:.62rem; letter-spacing:.1em; color:var(--text-muted); margin:4px 0 0 0; }

.ana-stats { display:grid; grid-template-columns:repeat(4, 1fr); gap:12px; }
.ana-stat-card {
  display:flex; flex-direction:column; align-items:center; gap:4px;
  padding:16px 10px; border:var(--border-width) solid var(--border);
  background:var(--panel-bg); border-radius:var(--radius); text-align:center;
}
.ana-stat-num { font-family:var(--font-d); font-size:1.3rem; font-weight:700; }
.ana-stat-label { font-family:var(--font-m); font-size:.48rem; letter-spacing:.14em; text-transform:uppercase; color:var(--text-muted); }

.ana-charts { display:grid; grid-template-columns:1.4fr 1fr; gap:14px; }
.ana-chart-panel {
  border:var(--border-width) solid var(--border); background:var(--panel-bg);
  border-radius:var(--radius); padding:16px; display:flex; flex-direction:column; gap:10px;
}
.ana-chart-title { font-family:var(--font-m); font-size:.62rem; letter-spacing:.14em; text-transform:uppercase; color:var(--text-muted); margin:0; }
.ana-chart-box { position:relative; width:100%; min-height:180px; }
.ana-chart-box canvas { width:100%; height:100%; }
.ana-chart-donut-box { display:flex; align-items:center; justify-content:center; gap:16px; flex-wrap:wrap; }
.ana-donut-legend { display:flex; flex-direction:column; gap:6px; }
.ana-legend-item { display:flex; align-items:center; gap:6px; }
.ana-legend-dot { width:8px; height:8px; border-radius:50%; flex-shrink:0; }
.ana-legend-label { font-family:var(--font-b); font-size:.72rem; color:var(--text-muted); }
.ana-legend-val { font-family:var(--font-m); font-size:.68rem; color:var(--text); margin-left:auto; }

.ana-section { display:flex; flex-direction:column; gap:10px; }
.ana-section-title { font-family:var(--font-m); font-size:.62rem; letter-spacing:.14em; text-transform:uppercase; color:var(--text-muted); margin:0; }

.ana-table-wrap { overflow-x:auto; }
.ana-table {
  width:100%; border-collapse:collapse;
  border:var(--border-width) solid var(--border); background:var(--panel-bg);
  border-radius:var(--radius);
}
.ana-table th, .ana-table td {
  padding:10px 14px; text-align:left;
  font-family:var(--font-b); font-size:.78rem;
  border-bottom:1px solid var(--border);
}
.ana-table th {
  font-family:var(--font-m); font-size:.56rem; letter-spacing:.12em;
  text-transform:uppercase; color:var(--text-muted); background:var(--surface);
}
.ana-table tbody tr:last-child td { border-bottom:none; }
.ana-agent-link { display:flex; align-items:center; gap:6px; text-decoration:none; color:var(--text); }
.ana-agent-link:hover { color:var(--accent); }
.ana-rate { font-family:var(--font-m); font-size:.72rem; font-weight:600; }
.rate-good { color:#22c55e; }
.rate-ok { color:#f59e0b; }
.rate-bad { color:#ef4444; }

/* ─────────────────────────────────────────────────────────────────
   COST TRACKER VIEW
───────────────────────────────────────────────────────────────── */
.cost-wrap { max-width:960px; margin:0 auto; display:flex; flex-direction:column; gap:20px; }
.cost-header { display:flex; align-items:flex-start; justify-content:space-between; gap:12px; flex-wrap:wrap; }
.cost-title { font-family:var(--font-d); font-size:1.2rem; font-weight:700; margin:0; }
.cost-sub { font-family:var(--font-m); font-size:.62rem; letter-spacing:.1em; color:var(--text-muted); margin:4px 0 0 0; }

.cost-overview { display:grid; grid-template-columns:repeat(4, 1fr); gap:12px; }
.cost-ov-card {
  display:flex; flex-direction:column; align-items:center; gap:4px;
  padding:16px 10px; border:var(--border-width) solid var(--border);
  background:var(--panel-bg); border-radius:var(--radius); text-align:center;
}
.cost-ov-spend { border-color:var(--accent); }
.cost-ov-label { font-family:var(--font-m); font-size:.48rem; letter-spacing:.14em; text-transform:uppercase; color:var(--text-muted); }
.cost-ov-num { font-family:var(--font-d); font-size:1.3rem; font-weight:700; }
.cost-ov-sub { font-family:var(--font-m); font-size:.48rem; color:var(--text-dim); }

.cost-budget-bar { width:100%; height:4px; background:var(--border); border-radius:2px; margin-top:4px; overflow:hidden; }
.cost-budget-fill { height:100%; background:var(--accent); transition:width .4s ease; border-radius:2px; }
.cost-budget-fill.bar-warn { background:#f59e0b; }
.cost-budget-fill.bar-danger { background:#ef4444; }

.cost-chart-panel {
  border:var(--border-width) solid var(--border); background:var(--panel-bg);
  border-radius:var(--radius); padding:16px; display:flex; flex-direction:column; gap:10px;
}
.cost-section-title { font-family:var(--font-m); font-size:.62rem; letter-spacing:.14em; text-transform:uppercase; color:var(--text-muted); margin:0; }
.cost-chart-box { position:relative; width:100%; min-height:180px; }
.cost-chart-box canvas { width:100%; height:100%; }

.cost-section { display:flex; flex-direction:column; gap:10px; }
.cost-table-wrap { overflow-x:auto; }

.cost-log { display:flex; flex-direction:column; gap:4px; }
.cost-log-row {
  display:flex; align-items:center; gap:10px; padding:10px 14px;
  border:var(--border-width) solid var(--border); background:var(--panel-bg);
  border-radius:var(--radius); flex-wrap:wrap;
}
.cost-log-agent { font-family:var(--font-b); font-size:.78rem; color:var(--text); flex:1; min-width:80px; }
.cost-log-model { font-size:.62rem; color:var(--text-dim); }
.cost-log-tokens { font-family:var(--font-m); font-size:.56rem; color:var(--text-muted); }
.cost-log-amount { font-family:var(--font-d); font-size:.78rem; font-weight:700; color:var(--accent); }
.cost-log-time { font-family:var(--font-m); font-size:.52rem; color:var(--text-dim); flex-shrink:0; }

/* ─────────────────────────────────────────────────────────────────
   COMMS HUB VIEW
───────────────────────────────────────────────────────────────── */
.comms-wrap { max-width:720px; margin:0 auto; display:flex; flex-direction:column; gap:20px; }
.comms-header { display:flex; align-items:flex-start; justify-content:space-between; gap:12px; flex-wrap:wrap; }
.comms-title { font-family:var(--font-d); font-size:1.2rem; font-weight:700; margin:0; }
.comms-sub { font-family:var(--font-m); font-size:.62rem; letter-spacing:.1em; color:var(--text-muted); margin:4px 0 0 0; }

.comms-tabs { display:flex; gap:4px; flex-wrap:wrap; }
.comms-tab {
  padding:5px 14px; background:none; border:var(--border-width) solid var(--border);
  color:var(--text-muted); font-family:var(--font-m); font-size:.58rem;
  letter-spacing:.1em; cursor:pointer; transition:color .15s, border-color .15s;
  border-radius:var(--radius);
}
.comms-tab:hover { color:var(--text); border-color:var(--border-hi); }
.comms-tab.active { color:var(--accent); border-color:var(--accent); }

.comms-feed { display:flex; flex-direction:column; gap:4px; }
.comms-item {
  display:flex; align-items:flex-start; gap:12px; padding:14px;
  border:var(--border-width) solid var(--border); background:var(--panel-bg);
  border-radius:var(--radius); cursor:pointer; transition:border-color .2s;
}
.comms-item:hover { border-color:var(--border-hi); }
.comms-item.unread { border-left:3px solid var(--accent); }
.comms-item-icon { flex-shrink:0; padding-top:2px; }
.comms-item-body { flex:1; min-width:0; }
.comms-item-top { display:flex; align-items:center; justify-content:space-between; gap:8px; margin-bottom:4px; }
.comms-item-label { font-family:var(--font-m); font-size:.5rem; letter-spacing:.12em; text-transform:uppercase; }
.comms-item-time { font-family:var(--font-m); font-size:.5rem; color:var(--text-dim); flex-shrink:0; }
.comms-item-title { font-family:var(--font-b); font-size:.82rem; font-weight:600; margin:0; color:var(--text); }
.comms-item-msg { font-family:var(--font-b); font-size:.74rem; color:var(--text-muted); margin:4px 0 0 0; line-height:1.5; }
.comms-unread-dot { width:8px; height:8px; border-radius:50%; background:var(--accent); flex-shrink:0; margin-top:6px; }

/* ─────────────────────────────────────────────────────────────────
   INTEGRATIONS VIEW
───────────────────────────────────────────────────────────────── */
.integ-wrap { max-width:960px; margin:0 auto; display:flex; flex-direction:column; gap:20px; }
.integ-header { display:flex; align-items:flex-start; justify-content:space-between; gap:12px; flex-wrap:wrap; }
.integ-title { font-family:var(--font-d); font-size:1.2rem; font-weight:700; margin:0; }
.integ-sub { font-family:var(--font-m); font-size:.62rem; letter-spacing:.1em; color:var(--text-muted); margin:4px 0 0 0; }
.integ-stat { display:flex; align-items:center; gap:6px; }
.integ-stat-num { font-family:var(--font-d); font-size:1.1rem; font-weight:700; color:var(--accent); }
.integ-stat-label { font-family:var(--font-m); font-size:.5rem; letter-spacing:.12em; color:var(--text-muted); text-transform:uppercase; }
.integ-cats { display:flex; gap:6px; flex-wrap:wrap; }

.integ-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(280px, 1fr)); gap:12px; }
.integ-card {
  display:flex; flex-direction:column; gap:10px; padding:16px;
  border:var(--border-width) solid var(--border); background:var(--panel-bg);
  border-radius:var(--radius); transition:border-color .2s;
}
.integ-card.connected { border-color:var(--accent); }
.integ-card:hover { border-color:var(--border-hi); }
.integ-card-icon { color:var(--accent); }
.integ-card-body { flex:1; }
.integ-card-name { font-family:var(--font-d); font-size:.88rem; font-weight:700; margin:0; }
.integ-card-cat { font-family:var(--font-m); font-size:.48rem; letter-spacing:.12em; text-transform:uppercase; color:var(--text-muted); }
.integ-card-desc { font-family:var(--font-b); font-size:.74rem; color:var(--text-muted); margin:4px 0 0 0; line-height:1.5; }
.integ-card-foot { display:flex; align-items:center; justify-content:space-between; gap:8px; padding-top:8px; border-top:1px solid var(--border); }
.integ-status { display:flex; align-items:center; gap:5px; font-family:var(--font-m); font-size:.56rem; letter-spacing:.1em; color:#22c55e; }

/* ─────────────────────────────────────────────────────────────────
   ACADEMY VIEW
───────────────────────────────────────────────────────────────── */
.acad-wrap { max-width:800px; margin:0 auto; display:flex; flex-direction:column; gap:20px; }
.acad-header { }
.acad-title { font-family:var(--font-d); font-size:1.2rem; font-weight:700; margin:0; }
.acad-sub { font-family:var(--font-m); font-size:.62rem; letter-spacing:.1em; color:var(--text-muted); margin:4px 0 0 0; }

.acad-progress-row { display:grid; grid-template-columns:repeat(3, 1fr); gap:12px; }
.acad-prog-card {
  display:flex; flex-direction:column; align-items:center; gap:4px; padding:16px;
  border:var(--border-width) solid var(--border); background:var(--panel-bg);
  border-radius:var(--radius); text-align:center;
}
.acad-prog-num { font-family:var(--font-d); font-size:1.3rem; font-weight:700; }
.acad-prog-label { font-family:var(--font-m); font-size:.48rem; letter-spacing:.14em; text-transform:uppercase; color:var(--text-muted); }

.acad-tracks { display:flex; flex-direction:column; gap:12px; }
.acad-track {
  border:var(--border-width) solid var(--border); background:var(--panel-bg);
  border-radius:var(--radius); overflow:hidden; transition:border-color .2s;
}
.acad-track:hover { border-color:var(--border-hi); }
.acad-track-hdr { display:flex; align-items:center; gap:14px; padding:16px; cursor:pointer; }
.acad-track-color { width:4px; height:48px; border-radius:2px; flex-shrink:0; }
.acad-track-info { flex:1; min-width:0; }
.acad-track-name { font-family:var(--font-d); font-size:.92rem; font-weight:700; margin:0; }
.acad-track-desc { font-family:var(--font-b); font-size:.74rem; color:var(--text-muted); margin:4px 0 0 0; }
.acad-track-meta { display:flex; gap:10px; margin-top:6px; font-family:var(--font-m); font-size:.5rem; letter-spacing:.1em; color:var(--text-dim); }
.acad-level { padding:1px 8px; border:1px solid; border-radius:2px; text-transform:uppercase; }
.level-beginner { color:#22c55e; border-color:#22c55e; }
.level-intermediate { color:#f59e0b; border-color:#f59e0b; }
.level-advanced { color:#a855f7; border-color:#a855f7; }

.acad-track-progress { flex-shrink:0; }
.acad-track-ring { position:relative; width:48px; height:48px; }
.acad-ring-svg { width:100%; height:100%; transform:rotate(-90deg); }
.acad-ring-bg { fill:none; stroke:var(--border); stroke-width:3; }
.acad-ring-fill { fill:none; stroke-width:3; stroke-linecap:round; transition:stroke-dasharray .6s ease; }
.acad-ring-pct {
  position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
  font-family:var(--font-m); font-size:.56rem; color:var(--text);
}

.acad-track-modules { padding:0 16px 16px; display:flex; flex-direction:column; gap:6px; border-top:1px solid var(--border); padding-top:12px; }
.acad-module { display:flex; align-items:center; gap:10px; padding:8px 0; border-bottom:1px solid var(--border); }
.acad-module:last-of-type { border-bottom:none; }
.acad-module-num { font-family:var(--font-m); font-size:.56rem; color:var(--text-dim); flex-shrink:0; width:20px; }
.acad-module-info { flex:1; }
.acad-module-name { font-family:var(--font-b); font-size:.78rem; display:block; }
.acad-module-dur { font-family:var(--font-m); font-size:.48rem; color:var(--text-dim); }
.acad-module-status { font-family:var(--font-m); font-size:.5rem; letter-spacing:.08em; flex-shrink:0; }
.acad-module-status.status-completed { color:#22c55e; }
.acad-module-status.status-in_progress { color:var(--accent); }
.acad-module-status.status-locked { color:var(--text-dim); }
.acad-module.locked .acad-module-name { color:var(--text-dim); }

.acad-cert-badge {
  display:flex; align-items:center; gap:8px; padding:10px 14px; margin-top:8px;
  border:1px dashed; border-radius:var(--radius);
  font-family:var(--font-m); font-size:.62rem; letter-spacing:.1em; color:var(--text-muted);
}

/* ─────────────────────────────────────────────────────────────────
   VAULT VIEW
───────────────────────────────────────────────────────────────── */
.vault-wrap { max-width:800px; margin:0 auto; display:flex; flex-direction:column; gap:20px; }
.vault-header { display:flex; align-items:flex-start; justify-content:space-between; gap:12px; flex-wrap:wrap; }
.vault-title { font-family:var(--font-d); font-size:1.2rem; font-weight:700; margin:0; }
.vault-sub { font-family:var(--font-m); font-size:.62rem; letter-spacing:.1em; color:var(--text-muted); margin:4px 0 0 0; }

.vault-stats { display:flex; gap:20px; flex-wrap:wrap; }
.vault-stat { display:flex; align-items:center; gap:6px; }
.vault-stat-num { font-family:var(--font-d); font-size:1rem; font-weight:700; }
.vault-stat-label { font-family:var(--font-m); font-size:.48rem; letter-spacing:.12em; text-transform:uppercase; color:var(--text-muted); }

.vault-list { display:flex; flex-direction:column; gap:6px; }
.vault-row {
  display:flex; align-items:center; gap:12px; padding:14px;
  border:var(--border-width) solid var(--border); background:var(--panel-bg);
  border-radius:var(--radius); flex-wrap:wrap;
}
.vault-row-icon { color:var(--accent); flex-shrink:0; }
.vault-row-info { flex:1; min-width:120px; }
.vault-row-name { font-family:var(--font-m); font-size:.78rem; font-weight:600; display:block; color:var(--text); }
.vault-row-service { font-family:var(--font-m); font-size:.48rem; letter-spacing:.1em; color:var(--text-dim); text-transform:uppercase; }
.vault-row-masked { font-size:.68rem; color:var(--text-dim); letter-spacing:.06em; }
.vault-row-meta { display:flex; align-items:center; gap:5px; }
.vault-row-used { font-family:var(--font-m); font-size:.48rem; color:var(--text-dim); }
.vault-row-actions { flex-shrink:0; }

/* Vault LLM Providers */
.vault-providers { margin-bottom:1.5rem; }
.vault-section-title { font-family:var(--font-d); font-size:1rem; font-weight:700; margin:0 0 .2rem 0; }
.vault-section-desc { font-family:var(--font-m); font-size:.6rem; color:var(--text-muted); margin:0 0 .8rem 0; }
.vault-provider-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(200px,1fr)); gap:12px; }
.vault-provider-card {
  background:var(--panel-bg); border:1px solid var(--border); border-radius:var(--radius);
  padding:1rem; display:flex; flex-direction:column; gap:.6rem; transition:border-color .2s;
}
.vault-provider-card.connected { border-color:var(--accent); }
.vault-provider-hdr { display:flex; align-items:center; gap:.5rem; }
.vault-provider-icon { font-size:1.2rem; }
.vault-provider-name { font-family:var(--font-d); font-size:.85rem; font-weight:600; }
.vault-provider-status { display:flex; align-items:center; gap:.4rem; font-family:var(--font-m); font-size:.55rem; color:var(--text-muted); }
.dot-off { width:6px; height:6px; border-radius:50%; background:var(--text-dim); display:inline-block; }

/* ─────────────────────────────────────────────────────────────────
   SETTINGS VIEW
───────────────────────────────────────────────────────────────── */
.settings-wrap { max-width:640px; margin:0 auto; display:flex; flex-direction:column; gap:24px; }
.settings-title { font-family:var(--font-d); font-size:1.2rem; font-weight:700; margin:0; }
.settings-sub { font-family:var(--font-m); font-size:.62rem; letter-spacing:.1em; color:var(--text-muted); margin:0; }

.settings-section {
  border:var(--border-width) solid var(--border); background:var(--panel-bg);
  border-radius:var(--radius); padding:18px; display:flex; flex-direction:column; gap:4px;
}
.settings-section-title {
  font-family:var(--font-m); font-size:.6rem; letter-spacing:.14em;
  text-transform:uppercase; color:var(--text-muted); margin:0 0 8px 0;
}
.settings-danger { border-color:#ef4444; }
.settings-danger .settings-section-title { color:#ef4444; }

.settings-row {
  display:flex; align-items:center; justify-content:space-between; gap:14px;
  padding:10px 0; border-bottom:1px solid var(--border);
}
.settings-row:last-child { border-bottom:none; }
.settings-row-info { flex:1; min-width:0; }
.settings-row-name { font-family:var(--font-b); font-size:.82rem; display:block; color:var(--text); }
.settings-row-desc { font-family:var(--font-b); font-size:.68rem; color:var(--text-dim); display:block; margin-top:2px; }

/* Toggle switch */
.settings-switch { position:relative; display:inline-block; width:36px; height:20px; flex-shrink:0; }
.settings-switch input { opacity:0; width:0; height:0; }
.settings-slider {
  position:absolute; cursor:pointer; inset:0;
  background:var(--border); border-radius:10px;
  transition:background .2s;
}
.settings-slider::before {
  content:''; position:absolute; width:16px; height:16px;
  left:2px; bottom:2px; background:var(--text-muted);
  border-radius:50%; transition:transform .2s, background .2s;
}
.settings-switch input:checked + .settings-slider { background:var(--accent); }
.settings-switch input:checked + .settings-slider::before { transform:translateX(16px); background:#fff; }

.settings-range-group { display:flex; align-items:center; gap:8px; flex-shrink:0; }

/* ── Comms Broadcast + Pin ── */
.comms-broadcast {
  display:flex; gap:8px; margin-bottom:1rem;
}
.comms-broadcast-input {
  flex:1; background:var(--panel-bg); border:1px solid var(--border);
  border-radius:var(--radius); padding:10px 14px; color:var(--text);
  font-size:.82rem; font-family:var(--font-b); outline:none;
}
.comms-broadcast-input:focus { border-color:var(--accent); }
.comms-pin-btn {
  background:none; border:none; color:var(--border); cursor:pointer;
  font-size:1rem; padding:4px; flex-shrink:0; transition:color .15s;
  align-self:flex-start; margin-top:4px;
}
.comms-pin-btn:hover { color:#f59e0b; }
.comms-pin-btn.pinned { color:#f59e0b; }

/* ── Blueprint Featured + Preview + Ratings ── */
.bp-featured { margin-bottom:1.5rem; }
.bp-featured-title { font-size:.85rem; font-family:var(--font-h); font-weight:700; text-transform:uppercase; letter-spacing:.08em; color:var(--text-muted); margin-bottom:.75rem; }
.bp-featured-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(240px, 1fr)); gap:1rem; }
.bp-featured-card {
  position:relative; overflow:hidden; padding:1rem; border-radius:var(--radius);
  border:1px solid var(--border); background:var(--panel-bg);
  cursor:pointer; transition:border-color .2s, transform .15s;
}
.bp-featured-card:hover { transform:translateY(-2px); }
.bp-featured-bar { position:absolute; top:0; left:0; right:0; height:3px; }
.bp-card-clickable { cursor:pointer; }
.bp-installed-badge {
  font-size:.6rem; padding:2px 6px; border-radius:3px;
  background:#22c55e20; color:#22c55e; font-family:var(--font-m);
  letter-spacing:.04em; text-transform:uppercase;
}
.bp-preview-rarity { font-size:.78rem; font-weight:600; margin-bottom:.5rem; }
.bp-preview-desc { font-size:.82rem; color:var(--text-muted); line-height:1.5; margin-bottom:1rem; }
.bp-preview-stats { display:flex; align-items:center; gap:1rem; margin-bottom:1rem; }
.bp-preview-config { display:flex; flex-direction:column; gap:4px; margin-bottom:1rem; }
.bp-preview-tools { display:flex; flex-wrap:wrap; gap:6px; margin-bottom:1rem; }
.bp-preview-installed {
  display:inline-block; padding:4px 12px; border-radius:4px;
  background:#22c55e20; color:#22c55e; font-size:.78rem;
  font-family:var(--font-m); margin-bottom:.75rem;
}
.bp-rate-section { display:flex; align-items:center; gap:8px; margin-top:.5rem; }
.bp-rate-label { font-size:.75rem; color:var(--text-muted); }
.bp-rate-stars { display:flex; gap:2px; }
.bp-rate-star { font-size:1.2rem; cursor:pointer; color:var(--border); transition:color .15s; }
.bp-rate-star.active { color:#f59e0b; }
.bp-rate-star:hover { color:#f59e0b; }

/* ── Resource Pool ── */
.resource-pool { display:flex; flex-direction:column; gap:8px; }
.resource-pool-row { display:flex; align-items:center; gap:10px; }
.resource-pool-label { font-size:.7rem; font-family:var(--font-m); text-transform:uppercase; letter-spacing:.06em; color:var(--text-muted); width:50px; }
.resource-pool-bar { flex:1; height:8px; background:var(--bg-alt); border-radius:4px; overflow:hidden; }
.resource-pool-fill { height:100%; border-radius:4px; transition:width .4s ease; }
.resource-pool-fill.fuel { background:#f59e0b; }
.resource-pool-fill.power { background:#22c55e; }
.resource-pool-fill.credits { background:#6366f1; }
.resource-pool-val { font-size:.68rem; font-family:var(--font-m); color:var(--text-muted); width:36px; text-align:right; }

/* ── Fleet Member Card with undock ── */
.fleet-member-card { position:relative; }
.fleet-member-card-link { display:flex; align-items:center; gap:.75rem; text-decoration:none; color:inherit; flex:1; }
.fd-undock-btn { position:absolute; top:6px; right:6px; opacity:.5; transition:opacity .2s; }
.fd-undock-btn:hover { opacity:1; color:#ef4444; }

/* ─────────────────────────────────────────────────────────────────
   AGENT CHAT
───────────────────────────────────────────────────────────────── */
.chat-panel {
  background:var(--bg-alt); border:1px solid var(--border); border-radius:var(--radius);
  display:flex; flex-direction:column; overflow:hidden;
}
.chat-messages {
  min-height:180px; max-height:360px; overflow-y:auto;
  padding:14px; display:flex; flex-direction:column; gap:10px;
}
.chat-empty { text-align:center; color:var(--text-muted); font-size:.78rem; padding:2rem 0; }
.chat-msg { display:flex; align-items:flex-end; gap:8px; }
.chat-msg.user { justify-content:flex-end; }
.chat-msg.agent { justify-content:flex-start; }
.chat-avatar {
  width:28px; height:28px; border-radius:50%; flex-shrink:0;
  display:flex; align-items:center; justify-content:center;
  font-size:.6rem; font-weight:700; color:#fff;
}
.chat-bubble {
  max-width:70%; padding:8px 12px; border-radius:12px;
  font-size:.78rem; line-height:1.4; color:var(--text);
  background:var(--panel-bg); border:1px solid var(--border);
}
.chat-bubble.user-bubble {
  background:var(--accent); color:var(--bg); border-color:var(--accent);
}
.chat-input-row {
  display:flex; gap:8px; padding:10px 14px;
  border-top:1px solid var(--border);
}
.chat-input {
  flex:1; background:var(--panel-bg); border:1px solid var(--border);
  border-radius:var(--radius); padding:8px 12px; color:var(--text);
  font-size:.78rem; font-family:var(--font-b); outline:none;
}
.chat-input:focus { border-color:var(--accent); }

/* Typing indicator */
.chat-typing { display:inline-flex; gap:4px; padding:4px 0; }
.chat-typing span {
  width:6px; height:6px; border-radius:50%; background:var(--text-muted);
  animation:chatBounce .6s infinite alternate;
}
.chat-typing span:nth-child(2) { animation-delay:.2s; }
.chat-typing span:nth-child(3) { animation-delay:.4s; }
@keyframes chatBounce { from { opacity:.3; transform:translateY(0); } to { opacity:1; transform:translateY(-4px); } }

/* ─────────────────────────────────────────────────────────────────
   NOTIFICATION TOASTS
───────────────────────────────────────────────────────────────── */
.notify-container {
  position:fixed; top:60px; right:12px; z-index:500;
  display:flex; flex-direction:column; gap:8px; pointer-events:none;
}
.notify-toast {
  display:flex; align-items:stretch; background:var(--panel-bg);
  border:var(--border-width) solid var(--border); border-radius:var(--radius);
  min-width:280px; max-width:360px; pointer-events:auto;
  animation:notifyIn .3s ease; overflow:hidden;
}
.notify-toast.dismiss { animation:notifyOut .3s ease forwards; }
@keyframes notifyIn { from { opacity:0; transform:translateX(20px); } to { opacity:1; transform:translateX(0); } }
@keyframes notifyOut { to { opacity:0; transform:translateX(20px); } }
.notify-toast-bar { width:4px; flex-shrink:0; }
.notify-toast-body { flex:1; padding:10px 12px; }
.notify-toast-title { font-family:var(--font-b); font-size:.78rem; font-weight:600; display:block; color:var(--text); }
.notify-toast-msg { font-family:var(--font-b); font-size:.68rem; color:var(--text-muted); display:block; margin-top:2px; }
.notify-toast-close {
  background:none; border:none; color:var(--text-dim); cursor:pointer;
  padding:8px 10px; font-size:1rem; align-self:flex-start;
}

/* ─────────────────────────────────────────────────────────────────
   PHASE 2 + 3 + 4 MOBILE RESPONSIVE
───────────────────────────────────────────────────────────────── */
@media (max-width:768px) {
  .view-topbar { flex-direction:column; align-items:stretch; }
  .view-topbar-l { flex-direction:column; }
  .search-input { width:100%; }
  .agents-grid { grid-template-columns:1fr; }
  .fleet-grid { grid-template-columns:1fr; }
  .fleet-member-grid { grid-template-columns:1fr; }
  .detail-grid { grid-template-columns:1fr; }
  .builder-row { grid-template-columns:1fr; }
  .task-row-main { flex-wrap:wrap; }
  .bp-grid { grid-template-columns:1fr; }
  .ana-stats { grid-template-columns:repeat(2, 1fr); }
  .ana-charts { grid-template-columns:1fr; }
  .cost-overview { grid-template-columns:repeat(2, 1fr); }
  .cost-log-row { font-size:.72rem; }
  .integ-grid { grid-template-columns:1fr; }
  .acad-progress-row { grid-template-columns:1fr; }
  .acad-track-hdr { flex-wrap:wrap; }
  .vault-row { flex-direction:column; align-items:flex-start; }
  .settings-row { flex-direction:column; align-items:flex-start; gap:8px; }
  .bell-dropdown { width:calc(100vw - 24px); right:-50px; }
}

/* ─────────────────────────────────────────────────────────────────
   PWA SAFE AREAS
───────────────────────────────────────────────────────────────── */
@supports (padding: env(safe-area-inset-top)) {
  .app-hdr { padding-top:env(safe-area-inset-top); height:calc(52px + env(safe-area-inset-top)); }
  .app-sidebar { top:calc(52px + env(safe-area-inset-top)); }
  .app-main { margin-top:calc(52px + env(safe-area-inset-top)); }
  .app-tabbar { padding-bottom:env(safe-area-inset-bottom); height:calc(60px + env(safe-area-inset-bottom)); }
}

/* ─────────────────────────────────────────────────────────────────
   GAMIFICATION — Ranks, XP, Health, Ship Classes
───────────────────────────────────────────────────────────────── */

/* Rank Badge (sidebar compact) */
.rank-badge-compact { display:flex; align-items:center; gap:6px; padding:6px 10px; font-size:.72rem; color:var(--text-muted); border-top:1px solid var(--border); margin-top:auto; }
.rank-icon { font-size:.9rem; }
.rank-name { font-family:var(--font-m); letter-spacing:.06em; text-transform:uppercase; }

/* Rank Card (home dashboard) */
.rank-card { background:var(--panel-bg); border:1px solid var(--border); border-radius:var(--radius); padding:14px; }
.rank-card-top { display:flex; align-items:center; gap:10px; margin-bottom:10px; }
.rank-icon-lg { font-size:1.6rem; }
.rank-card-info { display:flex; flex-direction:column; }
.rank-card-name { font-family:var(--font-h); font-weight:700; font-size:.95rem; color:var(--text); }
.rank-card-xp { font-size:.72rem; color:var(--accent); font-family:var(--font-m); }
.rank-progress { height:6px; background:var(--bg-alt); border-radius:3px; overflow:hidden; }
.rank-progress-bar { height:100%; background:var(--accent); border-radius:3px; transition:width .4s ease; }
.rank-progress-label { display:block; margin-top:6px; font-size:.68rem; color:var(--text-muted); font-family:var(--font-m); }

/* Health Bars (spaceship cards) */
.health-bars { display:flex; flex-direction:column; gap:4px; margin-top:8px; }
.health-bar-row { display:flex; align-items:center; gap:6px; }
.health-label { font-size:.62rem; font-family:var(--font-m); text-transform:uppercase; letter-spacing:.08em; color:var(--text-muted); width:36px; }
.health-bar { flex:1; height:5px; background:var(--bg-alt); border-radius:3px; overflow:hidden; }
.health-fill { height:100%; border-radius:3px; transition:width .4s ease; }
.health-fill.hull { background:#22c55e; }
.health-fill.fuel { background:#f59e0b; }
.health-fill.shield { background:#6366f1; }
.health-val { font-size:.6rem; font-family:var(--font-m); color:var(--text-muted); width:28px; text-align:right; }

/* Ship Class Badge */
.ship-class-badge { display:inline-flex; align-items:center; gap:4px; padding:2px 8px; font-size:.62rem; font-family:var(--font-m); letter-spacing:.06em; border-radius:10px; border:1px solid var(--border); color:var(--text-muted); }
.ship-class-badge.class-scout { border-color:#22c55e40; color:#22c55e; }
.ship-class-badge.class-cruiser { border-color:#6366f140; color:#6366f1; }
.ship-class-badge.class-dreadnought { border-color:#f59e0b40; color:#f59e0b; }
.ship-class-badge.class-flagship { border-color:#a855f740; color:#a855f7; }

/* ── Achievement Gallery ── */
.ach-gallery { display:grid; grid-template-columns:repeat(auto-fill, minmax(220px, 1fr)); gap:.75rem; }
.ach-card { display:flex; align-items:center; gap:.75rem; padding:.75rem 1rem; border-radius:var(--radius, 8px); border:1px solid var(--border, #222); background:var(--panel-bg, #111); transition:opacity .2s, border-color .2s; }
.ach-card.unlocked { border-color:var(--accent, #fff); }
.ach-card.locked { opacity:.4; filter:grayscale(1); }
.ach-icon { font-size:1.5rem; flex-shrink:0; }
.ach-info { display:flex; flex-direction:column; gap:.15rem; min-width:0; }
.ach-name { font-weight:600; font-size:.85rem; color:var(--text, #fff); }
.ach-desc { font-size:.72rem; color:var(--text-muted, #888); }
.ach-date { font-size:.65rem; color:var(--accent, #fff); font-family:var(--font-m, monospace); }

/* ── Resource Bar ── */
.res-bar { display:flex; gap:1rem; padding:.5rem .75rem; border-radius:var(--radius, 8px); background:var(--panel-bg, #111); border:1px solid var(--border, #222); }
.res-item { display:flex; align-items:center; gap:.3rem; font-size:.78rem; font-weight:500; color:var(--text, #fff); }
.res-icon { font-size:.9rem; }
.res-val { font-family:var(--font-m, monospace); }
.res-item.res-warning { color:#ef4444; }
.res-item.res-warning .res-icon { animation:pulse-warn 1.5s infinite; }
@keyframes pulse-warn { 0%,100%{opacity:1} 50%{opacity:.4} }

/* ── Captain's Log ── */
.captains-log .feed-item { border-left:2px solid var(--accent, #fff); padding-left:.75rem; }
.captains-log .feed-time { font-family:var(--font-m, monospace); font-size:.72rem; letter-spacing:.03em; }

/* ── Home Fleet Cards ── */
.home-ms-cards { display:grid; grid-template-columns:repeat(auto-fill, minmax(260px, 1fr)); gap:.75rem; }
.home-ms-card { display:flex; align-items:center; gap:.75rem; padding:.75rem 1rem; border-radius:var(--radius, 8px); border:1px solid var(--border, #222); background:var(--panel-bg, #111); text-decoration:none; color:var(--text, #fff); transition:border-color .2s; }
.home-ms-card:hover { border-color:var(--accent, #fff); }

/* ── PRO Gate ── */
.pro-gate { text-align:center; padding:2.5rem 1.5rem; margin:1rem 0; border-radius:var(--radius, 8px); border:1px dashed var(--border, #333); background:var(--panel-bg, #111); }
.pro-gate-icon { font-size:2.5rem; margin-bottom:.75rem; }
.pro-gate-title { font-size:1.1rem; font-weight:700; color:var(--text, #fff); margin-bottom:.5rem; }
.pro-gate-desc { font-size:.82rem; color:var(--text-muted, #888); margin-bottom:1rem; max-width:400px; margin-left:auto; margin-right:auto; }
.pro-upgrade-btn { background:linear-gradient(135deg, #a855f7, #6366f1); border:none; }

/* ── Fleets ── */
.ms-wrap { padding:1rem 0; }
.ms-header { display:flex; justify-content:space-between; align-items:flex-start; margin-bottom:1.5rem; gap:1rem; }
.ms-title { font-size:1.5rem; font-weight:700; }
.ms-sub { font-size:.82rem; color:var(--text-muted, #888); margin-top:.25rem; }
.ms-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(320px, 1fr)); gap:1rem; }
.ms-card { padding:1.25rem; border-radius:var(--radius, 8px); border:1px solid var(--border, #222); background:var(--panel-bg, #111); display:flex; flex-direction:column; gap:.75rem; transition:border-color .2s; }
.ms-card:hover { border-color:var(--accent, #fff); }
.ms-card-hdr { display:flex; justify-content:space-between; align-items:flex-start; gap:.5rem; }
.ms-card-info { display:flex; align-items:center; gap:.5rem; flex-wrap:wrap; }
.ms-card-name { font-weight:600; font-size:1rem; }
.ms-card-desc { font-size:.78rem; color:var(--text-muted, #888); line-height:1.4; }
.ms-card-stats { display:flex; flex-wrap:wrap; gap:.75rem; }
.ms-stat { font-size:.75rem; color:var(--text-muted, #888); }
.ms-card-role { font-size:.78rem; color:var(--text-muted, #888); }
.ms-card-actions { display:flex; gap:.5rem; }
.ms-bridge-desc { font-size:.85rem; color:var(--text-muted, #888); margin-bottom:1rem; line-height:1.5; }

/* ── Crew ── */
.ms-crew-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(200px, 1fr)); gap:.75rem; }
.ms-crew-card { display:flex; align-items:center; gap:.75rem; padding:.75rem; border-radius:var(--radius, 8px); border:1px solid var(--border, #222); background:var(--bg-alt, #0a0a0a); }
.ms-crew-avatar { width:36px; height:36px; border-radius:50%; background:var(--accent, #fff); color:var(--bg, #000); display:flex; align-items:center; justify-content:center; font-size:.7rem; font-weight:700; flex-shrink:0; }
.ms-crew-info { display:flex; flex-direction:column; gap:.1rem; }
.ms-crew-name { font-size:.82rem; font-weight:600; }
.ms-crew-role { font-size:.7rem; text-transform:uppercase; letter-spacing:.05em; }
.ms-role-captain { color:#f59e0b; }
.ms-role-officer { color:#6366f1; }
.ms-role-engineer { color:#06b6d4; }
.ms-role-crew { color:var(--text-muted, #888); }

/* ── Bridge Stats ── */
.ms-bridge-stats { display:grid; grid-template-columns:repeat(auto-fill, minmax(120px, 1fr)); gap:.75rem; }
.ms-bstat { text-align:center; padding:.75rem .5rem; border-radius:var(--radius, 8px); border:1px solid var(--border, #222); background:var(--bg-alt, #0a0a0a); }
.ms-bstat-val { display:block; font-size:1.5rem; font-weight:700; font-family:var(--font-m, monospace); color:var(--accent, #fff); }
.ms-bstat-label { font-size:.68rem; color:var(--text-muted, #888); text-transform:uppercase; letter-spacing:.03em; }
.ms-captain-actions { display:flex; gap:.5rem; flex-wrap:wrap; }

/* ── Space Stations ── */
.ss-wrap { padding:1rem 0; }
.ss-header { display:flex; justify-content:space-between; align-items:flex-start; margin-bottom:1.5rem; gap:1rem; }
.ss-title { font-size:1.5rem; font-weight:700; }
.ss-sub { font-size:.82rem; color:var(--text-muted, #888); margin-top:.25rem; }
.ss-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(320px, 1fr)); gap:1rem; }
.ss-card { padding:1.25rem; border-radius:var(--radius, 8px); border:1px solid var(--border, #222); background:var(--panel-bg, #111); display:flex; flex-direction:column; gap:.75rem; transition:border-color .2s; }
.ss-card:hover { border-color:var(--accent, #fff); }
.ss-card-hdr { display:flex; justify-content:space-between; align-items:flex-start; gap:.5rem; }
.ss-card-info { display:flex; align-items:center; gap:.5rem; flex-wrap:wrap; }
.ss-card-name { font-weight:600; font-size:1rem; }
.ss-card-desc { font-size:.78rem; color:var(--text-muted, #888); line-height:1.4; }
.ss-card-stats { display:flex; flex-wrap:wrap; gap:.75rem; }
.ss-card-actions { display:flex; gap:.5rem; }
.ss-tier { font-size:.65rem; padding:.15rem .5rem; border-radius:3px; font-weight:600; text-transform:uppercase; letter-spacing:.04em; }
.ss-tier-enterprise { background:#a855f720; color:#a855f7; }
.ss-tier-standard { background:#6366f120; color:#6366f1; }

/* ── Leaderboard ── */
.ss-leaderboard { display:flex; flex-direction:column; gap:.5rem; }
.ss-lb-row { display:flex; align-items:center; gap:.75rem; padding:.6rem .75rem; border-radius:var(--radius, 8px); background:var(--bg-alt, #0a0a0a); border:1px solid var(--border, #222); }
.ss-lb-rank { font-size:1rem; width:2rem; text-align:center; flex-shrink:0; }
.ss-lb-name { flex:1; font-weight:600; font-size:.85rem; }
.ss-lb-missions { font-size:.75rem; color:var(--text-muted, #888); }
.ss-lb-xp { font-size:.75rem; font-family:var(--font-m, monospace); color:var(--accent, #fff); }

/* ═══════════════════════════════════════════════════════════════════
   PHASE 1: Error Boundaries + Accessibility
═══════════════════════════════════════════════════════════════════ */

/* ── Error Boundary ── */
.err-boundary {
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  text-align:center; padding:60px 24px; gap:12px; min-height:50vh;
}
.err-boundary-icon { font-size:2.5rem; opacity:.5; }
.err-boundary-title { font-family:var(--font-d, var(--font-h)); font-size:1.1rem; color:var(--text); margin:0; }
.err-boundary-msg { font-size:.82rem; color:var(--text-muted); margin:0; }
.err-boundary-detail {
  background:var(--bg-alt); border:1px solid var(--border); border-radius:var(--radius);
  padding:10px 14px; font-family:var(--font-m); font-size:.68rem; color:#ef4444;
  max-width:400px; word-break:break-word; white-space:pre-wrap;
}
.err-boundary-actions { display:flex; gap:8px; margin-top:8px; }

/* ── Skip to Content (a11y) ── */
.skip-to-content {
  position:absolute; top:-40px; left:0; z-index:999;
  background:var(--accent); color:var(--bg); padding:8px 16px;
  font-family:var(--font-m); font-size:.75rem; text-decoration:none;
  transition:top .2s;
}
.skip-to-content:focus { top:0; }

/* ── Focus Visible ── */
*:focus-visible {
  outline:2px solid var(--accent);
  outline-offset:2px;
}
.side-link:focus-visible { background:var(--surface, var(--bg-alt)); }

/* ── Screen Reader Only ── */
.sr-only {
  position:absolute; width:1px; height:1px; padding:0; margin:-1px;
  overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0;
}

/* ═══════════════════════════════════════════════════════════════════
   PHASE 2: Command Palette + Keyboard Shortcuts + Onboarding
═══════════════════════════════════════════════════════════════════ */

/* ── Command Palette ── */
.cmd-palette { position:fixed; inset:0; z-index:400; display:none; align-items:flex-start; justify-content:center; padding-top:20vh; }
.cmd-palette.open { display:flex; }
.cmd-palette-backdrop { position:absolute; inset:0; background:rgba(0,0,0,.6); backdrop-filter:blur(4px); }
.cmd-palette-box {
  position:relative; width:100%; max-width:520px; background:var(--panel-bg, #111);
  border:1px solid var(--border); border-radius:var(--radius);
  box-shadow:0 16px 48px rgba(0,0,0,.5); overflow:hidden;
  animation:cmdSlideIn .15s ease;
}
@keyframes cmdSlideIn { from { opacity:0; transform:translateY(-10px); } to { opacity:1; transform:translateY(0); } }
.cmd-palette-input-wrap {
  display:flex; align-items:center; gap:8px; padding:12px 16px;
  border-bottom:1px solid var(--border);
}
.cmd-palette-input {
  flex:1; background:none; border:none; color:var(--text);
  font-family:var(--font-b); font-size:.88rem; outline:none;
}
.cmd-palette-input::placeholder { color:var(--text-dim, var(--text-muted)); }
.cmd-palette-kbd {
  font-family:var(--font-m); font-size:.55rem; padding:2px 6px;
  border:1px solid var(--border); border-radius:3px; color:var(--text-muted);
}
.cmd-palette-results { max-height:320px; overflow-y:auto; }
.cmd-result {
  display:flex; align-items:center; gap:10px; padding:10px 16px;
  cursor:pointer; transition:background .1s; border-left:2px solid transparent;
}
.cmd-result:hover, .cmd-result.selected { background:var(--surface, var(--bg-alt)); }
.cmd-result.selected { border-left-color:var(--accent); }
.cmd-result-label { flex:1; font-size:.82rem; color:var(--text); }
.cmd-result-type { font-family:var(--font-m); font-size:.55rem; color:var(--text-dim, var(--text-muted)); letter-spacing:.08em; text-transform:uppercase; }
.cmd-no-results { padding:24px 16px; text-align:center; color:var(--text-muted); font-size:.78rem; }

/* ── Keyboard Shortcut Help ── */
.kb-shortcut-grid { display:flex; flex-direction:column; gap:4px; }
.kb-section-title {
  font-family:var(--font-m); font-size:.58rem; letter-spacing:.14em;
  color:var(--text-muted); text-transform:uppercase; margin-top:10px;
  padding-bottom:4px; border-bottom:1px solid var(--border);
}
.kb-row {
  display:flex; align-items:center; justify-content:space-between;
  padding:6px 0; font-size:.78rem; color:var(--text);
}
.kb-row kbd {
  font-family:var(--font-m); font-size:.62rem; padding:2px 8px;
  background:var(--bg-alt); border:1px solid var(--border); border-radius:3px;
  color:var(--accent); min-width:22px; text-align:center;
}

/* ── Onboarding Tour ── */
.onb-overlay { position:fixed; inset:0; z-index:500; }
.onb-backdrop { position:absolute; inset:0; background:rgba(0,0,0,.7); }
.onb-spotlight {
  position:fixed; border:2px solid var(--accent); border-radius:var(--radius);
  box-shadow:0 0 0 9999px rgba(0,0,0,.6); z-index:501;
  transition:all .3s ease; pointer-events:none;
}
.onb-tooltip {
  z-index:502; background:var(--panel-bg, #111); border:1px solid var(--accent);
  border-radius:var(--radius); padding:20px; width:300px;
  box-shadow:0 8px 32px rgba(0,0,0,.4);
}
.onb-tooltip-step { font-family:var(--font-m); font-size:.55rem; color:var(--accent); letter-spacing:.12em; margin-bottom:6px; }
.onb-tooltip-title { font-family:var(--font-d, var(--font-h)); font-size:.95rem; font-weight:700; margin:0 0 6px 0; color:var(--text); }
.onb-tooltip-text { font-size:.78rem; color:var(--text-muted); line-height:1.6; margin:0 0 14px 0; }
.onb-tooltip-actions { display:flex; gap:8px; justify-content:flex-end; }

/* ═══════════════════════════════════════════════════════════════════
   PHASE 3: Agent Templates
═══════════════════════════════════════════════════════════════════ */
.builder-template-row {
  display:flex; align-items:center; gap:8px; padding:10px 0;
  margin-bottom:6px; border-bottom:1px solid var(--border);
}
.builder-template-label {
  font-family:var(--font-m); font-size:.62rem; letter-spacing:.1em;
  color:var(--text-muted); text-transform:uppercase; flex-shrink:0;
}

/* ═══════════════════════════════════════════════════════════════════
   PHASE 4: PWA Install Banner
═══════════════════════════════════════════════════════════════════ */
.install-banner {
  position:fixed; bottom:70px; left:50%; transform:translateX(-50%) translateY(100px);
  z-index:250; background:var(--panel-bg, #111); border:1px solid var(--accent);
  border-radius:var(--radius); padding:12px 18px;
  display:flex; align-items:center; gap:12px; box-shadow:0 8px 24px rgba(0,0,0,.4);
  transition:transform .3s ease; max-width:90vw;
}
.install-banner.show { transform:translateX(-50%) translateY(0); }
.install-banner-text { font-size:.78rem; color:var(--text); }
.install-banner-actions { display:flex; gap:6px; flex-shrink:0; }

/* ═══════════════════════════════════════════════════════════════════
   PHASE 5: Academy Tutorials
═══════════════════════════════════════════════════════════════════ */
.acad-section-title { font-size:1.1rem; font-weight:700; color:var(--text); margin:0 0 .25rem 0; }
.acad-section-sub { font-size:.8rem; color:var(--text-muted); margin:0 0 1rem 0; }

.tut-section { margin-bottom:1.5rem; }
.tut-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(340px, 1fr)); gap:1rem; }
.tut-card {
  padding:1.25rem; border-radius:var(--radius); border:1px solid var(--border);
  background:var(--panel-bg, #111); display:flex; flex-direction:column; gap:.75rem;
  transition:border-color .2s;
}
.tut-card:hover { border-color:var(--accent); }
.tut-card.tut-complete { border-color:#22c55e40; }
.tut-card-hdr { display:flex; gap:.75rem; align-items:flex-start; }
.tut-card-icon { font-size:1.5rem; flex-shrink:0; }
.tut-card-info { flex:1; }
.tut-card-name { font-weight:600; font-size:.92rem; margin:0 0 .2rem 0; color:var(--text); }
.tut-card-desc { font-size:.75rem; color:var(--text-muted); margin:0; line-height:1.4; }

.tut-steps { display:flex; flex-direction:column; gap:.35rem; }
.tut-step {
  display:flex; align-items:center; gap:.5rem; font-size:.75rem; color:var(--text-muted);
  padding:.3rem 0;
}
.tut-step.done { color:#22c55e; }
.tut-step.active { color:var(--accent); font-weight:600; }
.tut-step-check {
  width:20px; height:20px; border-radius:50%; display:flex; align-items:center; justify-content:center;
  font-size:.55rem; border:1px solid var(--border); flex-shrink:0;
}
.tut-step.done .tut-step-check { background:#22c55e20; border-color:#22c55e; color:#22c55e; }
.tut-step.active .tut-step-check { background:var(--accent)20; border-color:var(--accent); color:var(--accent); }
.tut-step-text { flex:1; }

.tut-card-footer { display:flex; align-items:center; gap:.75rem; margin-top:auto; }
.tut-progress-bar { flex:1; height:4px; background:var(--bg-alt); border-radius:2px; overflow:hidden; }
.tut-progress-fill { height:100%; background:var(--accent); border-radius:2px; transition:width .3s; }
.tut-progress-label { font-size:.65rem; color:var(--text-muted); font-family:var(--font-m); flex-shrink:0; }
.tut-badge-done { font-size:.65rem; color:#22c55e; font-weight:600; flex-shrink:0; }

/* ═══════════════════════════════════════════════════════════════════
   PHASE 6: Responsive Fixes for New Features
═══════════════════════════════════════════════════════════════════ */
.app-main { overflow-x:hidden; }

@media (max-width:768px) {
  .cmd-palette { padding-top:10vh; }
  .cmd-palette-box { max-width:calc(100vw - 24px); margin:0 12px; }
  .onb-tooltip { width:calc(100vw - 48px); max-width:300px; }
  .kb-shortcut-grid { font-size:.72rem; }
  .tut-grid { grid-template-columns:1fr; }
  .builder-template-row { flex-wrap:wrap; }
}

@media (max-width:480px) {
  .cmd-palette { padding-top:5vh; }
  .cmd-result { min-height:44px; }
  .onb-tooltip-actions .btn { min-height:44px; }
  .kb-row kbd { min-height:28px; display:inline-flex; align-items:center; }
  .install-banner { bottom:80px; flex-direction:column; text-align:center; }
}

/* ═══════════════════════════════════════════════════════════════════
   PAGE TRANSITIONS
═══════════════════════════════════════════════════════════════════ */
.view-exit { opacity:0; transform:translateY(-6px); transition:opacity 120ms ease,transform 120ms ease; }
.view-enter { animation:viewEnter 200ms ease forwards; }
@keyframes viewEnter { from { opacity:0; transform:translateY(6px); } to { opacity:1; transform:translateY(0); } }
@media (prefers-reduced-motion:reduce) {
  .view-exit,.view-enter { animation:none!important; transition:none!important; opacity:1!important; transform:none!important; }
}

/* ═══════════════════════════════════════════════════════════════════
   CAPTAIN'S LOG (Audit Log)
═══════════════════════════════════════════════════════════════════ */
.log-wrap { max-width:900px; margin:0 auto; padding:24px 0; }
.log-header { display:flex; justify-content:space-between; align-items:flex-start; margin-bottom:20px; }
.log-title { font-family:var(--font-h); font-size:1.5rem; color:var(--text); margin:0 0 4px; }
.log-sub { color:var(--text-muted); font-size:.82rem; margin:0; }
.log-count { color:var(--text-muted); font-size:.78rem; font-family:var(--font-m); white-space:nowrap; }

.log-filter-bar { display:flex; gap:8px; margin-bottom:16px; align-items:center; flex-wrap:wrap; }
.filter-input { background:var(--surface,var(--bg)); border:1px solid var(--border); color:var(--text);
  padding:6px 10px; border-radius:var(--radius); font-size:.82rem; font-family:var(--font-m); flex:1; min-width:120px; }
.filter-input:focus { border-color:var(--accent); outline:none; }

.log-timeline { display:flex; flex-direction:column; gap:2px; }
.log-entry { display:flex; gap:10px; padding:10px 12px; border-radius:var(--radius);
  border:1px solid transparent; transition:border-color .15s; }
.log-entry:hover { border-color:var(--border); background:var(--surface,rgba(255,255,255,.03)); }
.log-entry-icon { flex-shrink:0; width:28px; height:28px; display:flex; align-items:center; justify-content:center;
  border-radius:50%; background:rgba(255,255,255,.04); }
.log-entry-body { flex:1; min-width:0; }
.log-entry-top { display:flex; justify-content:space-between; align-items:center; margin-bottom:2px; }
.log-entry-badge { font-family:var(--font-m); font-size:.7rem; text-transform:uppercase; letter-spacing:.04em; }
.log-entry-time { font-family:var(--font-m); font-size:.7rem; color:var(--text-muted); }
.log-entry-desc { font-size:.82rem; color:var(--text); display:block; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.log-empty { text-align:center; padding:40px 20px; color:var(--text-muted); font-size:.85rem; }

/* ═══════════════════════════════════════════════════════════════════
   COMMAND PALETTE — Data Separator
═══════════════════════════════════════════════════════════════════ */
.cmd-result-sep { font-size:.65rem; text-transform:uppercase; letter-spacing:.06em; color:var(--text-muted);
  padding:8px 16px 4px; border-top:1px solid var(--border); margin-top:4px; font-family:var(--font-m); }

/* ═══════════════════════════════════════════════════════════════════
   RESPONSIVE — Phase 1 additions
═══════════════════════════════════════════════════════════════════ */
@media (max-width:768px) {
  .log-header { flex-direction:column; gap:8px; }
  .log-filter-bar { flex-direction:column; }
  .log-filter-bar .filter-select, .log-filter-bar .filter-input { width:100%; }
}
@media (max-width:480px) {
  .log-entry { padding:8px; gap:8px; }
  .log-entry-icon { width:24px; height:24px; }
}

/* ═══════════════════════════════════════════════════════════════════
   DASHBOARD WIDGETS — Draggable Home Cards
═══════════════════════════════════════════════════════════════════ */
.widget-card {
  position:relative;
  border:1px solid var(--border);
  border-radius:var(--radius);
  background:var(--panel-bg,rgba(255,255,255,.02));
  padding:16px;
  transition:border-color .2s, box-shadow .2s, opacity .2s, transform .15s;
}
.widget-card:hover { border-color:var(--border-hi,var(--accent)); }
.widget-handle {
  position:absolute; top:8px; right:10px;
  cursor:grab; font-size:.85rem; color:var(--text-muted);
  opacity:.3; transition:opacity .15s; user-select:none;
  letter-spacing:1px; z-index:2;
}
.widget-handle:active { cursor:grabbing; }
.widget-card:hover .widget-handle { opacity:.7; }
.widget-card.dragging { opacity:.4; transform:scale(.97); border-color:var(--accent); }
.widget-card.drag-over { border-color:var(--accent); box-shadow:0 0 0 2px var(--glow,rgba(255,255,255,.08)); }

.home-reset-layout {
  margin-top:8px; font-size:.72rem; padding:4px 12px;
  opacity:.6; transition:opacity .15s;
}
.home-reset-layout:hover { opacity:1; }

/* Ensure home-widgets is a flex column for proper DnD */
.home-widgets { display:flex; flex-direction:column; gap:16px; }

/* Widget card inner spacing adjustments */
.widget-card .home-stats { margin:0; }
.widget-card .home-section { margin:0; }
.widget-card .home-section-title { margin-top:0; }

@media (max-width:768px) {
  .widget-card { padding:12px; }
  .widget-handle { top:6px; right:8px; font-size:.75rem; }
}
@media (max-width:480px) {
  .widget-card { padding:10px; }
}

/* ═══════════════════════════════════════════════════════════════════
   THEME CREATOR
═══════════════════════════════════════════════════════════════════ */
.tc-wrap { max-width:960px; margin:0 auto; padding:24px 0; }
.tc-header { margin-bottom:20px; }
.tc-title { font-family:var(--font-h); font-size:1.5rem; color:var(--text); margin:0 0 4px; }
.tc-sub { color:var(--text-muted); font-size:.82rem; margin:0; }

.tc-layout { display:grid; grid-template-columns:1fr 1fr; gap:20px; margin-bottom:20px; }
.tc-panel { border:1px solid var(--border); border-radius:var(--radius); padding:16px; background:var(--panel-bg,rgba(255,255,255,.02)); }
.tc-panel-title { font-family:var(--font-h); font-size:.9rem; color:var(--text); margin:0 0 14px; text-transform:uppercase; letter-spacing:.04em; }

.tc-grid { display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.tc-field { display:flex; flex-direction:column; gap:4px; }
.tc-label { font-size:.72rem; color:var(--text-muted); text-transform:uppercase; letter-spacing:.04em; font-family:var(--font-m); }

.tc-color-row { display:flex; gap:6px; align-items:center; }
.tc-color {
  width:32px; height:32px; padding:0; border:1px solid var(--border);
  border-radius:var(--radius); cursor:pointer; background:none;
}
.tc-color::-webkit-color-swatch-wrapper { padding:1px; }
.tc-color::-webkit-color-swatch { border:none; border-radius:2px; }
.tc-hex {
  flex:1; background:var(--surface,var(--bg)); border:1px solid var(--border);
  color:var(--text); padding:4px 8px; border-radius:var(--radius);
  font-size:.78rem; font-family:var(--font-m); max-width:80px;
}
.tc-hex:focus { border-color:var(--accent); outline:none; }

.tc-select {
  width:100%; background:var(--surface,var(--bg)); border:1px solid var(--border);
  color:var(--text); padding:6px 10px; border-radius:var(--radius);
  font-size:.82rem; font-family:var(--font-m);
}
.tc-select:focus { border-color:var(--accent); outline:none; }

.tc-range-row { display:flex; align-items:center; gap:10px; }
.tc-range { flex:1; accent-color:var(--accent); }
.tc-range-val { font-family:var(--font-m); font-size:.78rem; color:var(--text-muted); min-width:36px; }

.tc-actions {
  display:flex; gap:8px; flex-wrap:wrap; margin-bottom:20px;
  padding:12px 16px; border:1px solid var(--border); border-radius:var(--radius);
  background:var(--panel-bg,rgba(255,255,255,.02));
}

.tc-saved-list { display:flex; flex-direction:column; gap:6px; }
.tc-saved-item { display:flex; gap:6px; align-items:center; }
.tc-saved-item .tc-load-btn { flex:1; text-align:left; }
.tc-empty { color:var(--text-muted); font-size:.78rem; margin:0; }

.tc-preview { border:1px solid var(--border); border-radius:var(--radius); padding:16px; background:var(--panel-bg,rgba(255,255,255,.02)); }
.tc-preview-box { padding:16px; border:1px solid var(--border); border-radius:var(--radius); background:var(--bg); }
.tc-preview-card h3 { font-family:var(--font-h); color:var(--text); margin:0 0 8px; font-size:1rem; }
.tc-preview-card p { color:var(--text-muted); font-size:.85rem; margin:0 0 12px; }
.tc-preview-btns { display:flex; gap:8px; margin-bottom:12px; }
.tc-preview-stats { display:flex; gap:16px; }
.tc-preview-accent { color:var(--accent); font-size:.82rem; font-family:var(--font-m); }
.tc-preview-muted { color:var(--text-muted); font-size:.82rem; font-family:var(--font-m); }

@media (max-width:768px) {
  .tc-layout { grid-template-columns:1fr; }
  .tc-grid { grid-template-columns:1fr; }
  .tc-actions { flex-direction:column; }
}
@media (max-width:480px) {
  .tc-wrap { padding:16px 0; }
}

/* ═══════════════════════════════════════════════════════════════════
   ACTIVITY FEED
═══════════════════════════════════════════════════════════════════ */
.activity-feed-wrap {
  border:1px solid var(--border); border-radius:var(--radius);
  background:var(--panel-bg,rgba(255,255,255,.02)); overflow:hidden;
}
.activity-feed-header {
  display:flex; justify-content:space-between; align-items:center;
  padding:10px 14px; border-bottom:1px solid var(--border);
}
.activity-feed-title { font-family:var(--font-h); font-size:.82rem; text-transform:uppercase; letter-spacing:.04em; color:var(--text); }
.activity-feed-toggle { font-size:.7rem; padding:2px 8px; }

.activity-feed { max-height:280px; overflow-y:auto; }
.af-item {
  display:flex; align-items:center; gap:8px; padding:7px 14px;
  border-bottom:1px solid rgba(255,255,255,.03); font-size:.8rem;
  transition:background .1s;
}
.af-item:hover { background:rgba(255,255,255,.02); }
.af-item:last-child { border-bottom:none; }
.af-icon { flex-shrink:0; font-size:.85rem; }
.af-desc { flex:1; color:var(--text); min-width:0; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.af-time { flex-shrink:0; font-family:var(--font-m); font-size:.68rem; color:var(--text-muted); }
.af-empty { padding:20px; text-align:center; color:var(--text-muted); font-size:.82rem; }

/* ═══════════════════════════════════════════════════════════════════
   PRESENCE INDICATOR
═══════════════════════════════════════════════════════════════════ */
.presence-indicator { display:flex; align-items:center; gap:6px; padding:4px 0; }
.presence-dot {
  width:6px; height:6px; border-radius:50%; background:#22c55e;
  box-shadow:0 0 4px #22c55e; animation:presencePulse 2s infinite;
}
.presence-count { font-family:var(--font-m); font-size:.7rem; color:var(--text-muted); }
@keyframes presencePulse { 0%,100% { opacity:1; } 50% { opacity:.5; } }

/* ═══════════════════════════════════════════════════════════════════
   WORKFLOW LIST
═══════════════════════════════════════════════════════════════════ */
.wf-wrap { max-width:900px; margin:0 auto; padding:24px 0; }
.wf-header { display:flex; justify-content:space-between; align-items:flex-start; margin-bottom:20px; }
.wf-title { font-family:var(--font-h); font-size:1.5rem; color:var(--text); margin:0 0 4px; }
.wf-sub { color:var(--text-muted); font-size:.82rem; margin:0; }
.wf-list { display:grid; grid-template-columns:repeat(auto-fill, minmax(260px, 1fr)); gap:12px; }
.wf-card {
  display:block; position:relative; padding:14px; border:1px solid var(--border);
  border-radius:var(--radius); background:var(--panel-bg,rgba(255,255,255,.02));
  text-decoration:none; color:var(--text); transition:border-color .15s;
}
.wf-card:hover { border-color:var(--accent); }
.wf-card-top { display:flex; justify-content:space-between; align-items:center; margin-bottom:6px; }
.wf-card-name { font-family:var(--font-h); font-size:.9rem; }
.wf-card-count { font-family:var(--font-m); font-size:.7rem; color:var(--text-muted); }
.wf-card-meta { display:flex; gap:12px; font-size:.72rem; color:var(--text-muted); }
.wf-del-btn { position:absolute; top:8px; right:8px; font-size:.7rem; padding:2px 6px; }

/* ═══════════════════════════════════════════════════════════════════
   WORKFLOW EDITOR
═══════════════════════════════════════════════════════════════════ */
.wfe-wrap { height:calc(100vh - 80px); display:flex; flex-direction:column; }
.wfe-toolbar {
  display:flex; align-items:center; gap:10px; padding:8px 12px;
  border-bottom:1px solid var(--border); flex-shrink:0;
}
.wfe-name-input {
  flex:1; background:transparent; border:1px solid transparent; color:var(--text);
  font-family:var(--font-h); font-size:1rem; padding:4px 8px; border-radius:var(--radius);
}
.wfe-name-input:focus { border-color:var(--accent); outline:none; }
.wfe-toolbar-right { display:flex; gap:6px; }

.wfe-layout { display:flex; flex:1; min-height:0; }

/* Palette */
.wfe-palette {
  width:140px; flex-shrink:0; padding:12px; border-right:1px solid var(--border);
  overflow-y:auto; display:flex; flex-direction:column; gap:6px;
}
.wfe-palette-title { font-family:var(--font-h); font-size:.72rem; text-transform:uppercase; letter-spacing:.04em; color:var(--text-muted); margin:0; }
.wfe-palette-btn {
  display:flex; align-items:center; gap:6px; padding:8px 10px;
  border:1px solid var(--border); border-radius:var(--radius);
  background:var(--panel-bg,rgba(255,255,255,.02)); color:var(--text);
  font-size:.78rem; cursor:pointer; transition:border-color .15s;
}
.wfe-palette-btn:hover { border-color:var(--accent); }
.wfe-palette-icon { font-size:1rem; }
.wfe-sep { border:none; border-top:1px solid var(--border); margin:6px 0; }
.wfe-tool-btn { width:100%; }

/* Canvas area */
.wfe-canvas-wrap {
  flex:1; position:relative; overflow:hidden; background:
    radial-gradient(circle at 1px 1px, var(--border) .5px, transparent 0) 0 0 / 20px 20px;
}
.wfe-canvas { position:absolute; top:0; left:0; width:100%; height:100%; pointer-events:none; z-index:1; }
.wfe-nodes { position:absolute; top:0; left:0; width:100%; height:100%; z-index:2; }

/* Nodes */
.wfe-node {
  position:absolute; width:140px; background:var(--surface,var(--bg));
  border:1px solid var(--border); border-radius:var(--radius);
  box-shadow:0 2px 8px rgba(0,0,0,.3); transition:box-shadow .15s, border-color .15s;
  cursor:default; user-select:none;
}
.wfe-node.selected { border-color:var(--accent); box-shadow:0 0 12px var(--glow,rgba(255,255,255,.1)); }
.wfe-node.connecting { border-color:#f59e0b; }
.wfe-node.running { border-color:#6366f1; animation:nodeRun .6s infinite alternate; }
.wfe-node.completed { border-color:#22c55e; }
@keyframes nodeRun { from { box-shadow:0 0 6px #6366f1; } to { box-shadow:0 0 16px #6366f1; } }

.wfe-node-header {
  display:flex; align-items:center; gap:6px; padding:8px 10px;
  border-bottom:2px solid var(--border); cursor:grab; font-size:.78rem;
}
.wfe-node-header:active { cursor:grabbing; }
.wfe-node-icon { font-size:.9rem; }
.wfe-node-label { flex:1; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; color:var(--text); }

.wfe-node-ports { display:flex; justify-content:space-between; padding:6px 10px; }
.wfe-port {
  width:10px; height:10px; border-radius:50%; border:2px solid var(--accent);
  background:var(--bg); cursor:pointer; transition:background .1s;
}
.wfe-port:hover { background:var(--accent); }
.wfe-port-in { margin-left:-16px; }
.wfe-port-out { margin-right:-16px; }

/* Properties */
.wfe-props {
  width:220px; flex-shrink:0; padding:12px; border-left:1px solid var(--border);
  overflow-y:auto;
}
.wfe-props-empty { color:var(--text-muted); font-size:.82rem; }
.wfe-props-inner { display:flex; flex-direction:column; gap:10px; }
.wfe-props-type { font-family:var(--font-h); font-size:.85rem; color:var(--accent); }
.wfe-field { display:flex; flex-direction:column; gap:3px; }
.wfe-field label { font-size:.7rem; color:var(--text-muted); text-transform:uppercase; font-family:var(--font-m); }
.wfe-textarea {
  width:100%; min-height:60px; background:var(--surface,var(--bg)); border:1px solid var(--border);
  color:var(--text); padding:6px 8px; border-radius:var(--radius); font-size:.78rem;
  font-family:var(--font-m); resize:vertical;
}
.wfe-textarea:focus { border-color:var(--accent); outline:none; }
.wfe-props-actions { display:flex; gap:6px; margin-top:8px; }

@media (max-width:768px) {
  .wfe-layout { flex-direction:column; }
  .wfe-palette { width:100%; flex-direction:row; flex-wrap:wrap; border-right:none; border-bottom:1px solid var(--border); }
  .wfe-props { width:100%; border-left:none; border-top:1px solid var(--border); }
  .wfe-canvas-wrap { min-height:300px; }
}

/* ═══════════════════════════════════════════════════════════════════
   MISSION BOARD (Kanban)
═══════════════════════════════════════════════════════════════════ */
.mb-wrap { padding:24px 0; }
.mb-header { display:flex; justify-content:space-between; align-items:flex-start; margin-bottom:16px; flex-wrap:wrap; gap:12px; }
.mb-title { font-family:var(--font-h); font-size:1.5rem; color:var(--text); margin:0 0 4px; }
.mb-sub { color:var(--text-muted); font-size:.82rem; margin:0; }
.mb-controls { display:flex; gap:8px; align-items:center; flex-wrap:wrap; }

.mb-board {
  display:grid; grid-template-columns:repeat(4, 1fr); gap:12px;
  min-height:400px;
}

.mb-col {
  display:flex; flex-direction:column;
  border:1px solid var(--border); border-radius:var(--radius);
  background:var(--panel-bg,rgba(255,255,255,.02));
}
.mb-col-header {
  display:flex; justify-content:space-between; align-items:center;
  padding:10px 12px; border-bottom:2px solid var(--border);
}
.mb-col-title { font-family:var(--font-h); font-size:.78rem; text-transform:uppercase; letter-spacing:.04em; }
.mb-col-count { font-family:var(--font-m); font-size:.7rem; color:var(--text-muted); background:rgba(255,255,255,.05);
  padding:2px 6px; border-radius:8px; }

.mb-col-body { flex:1; padding:8px; display:flex; flex-direction:column; gap:6px; min-height:100px; transition:background .15s; }
.mb-col-body.mb-drop-target { background:rgba(255,255,255,.05); outline:2px dashed var(--accent); outline-offset:-4px; }

.mb-card {
  padding:10px; border:1px solid var(--border); border-radius:var(--radius);
  background:var(--surface,var(--bg)); cursor:grab; transition:border-color .15s, opacity .15s, transform .1s;
}
.mb-card:hover { border-color:var(--accent); }
.mb-card.mb-dragging { opacity:.4; transform:scale(.95); }
.mb-card-compact { padding:6px 10px; display:flex; justify-content:space-between; align-items:center; }

.mb-card-top { display:flex; justify-content:space-between; align-items:flex-start; gap:6px; margin-bottom:4px; }
.mb-card-title { font-size:.82rem; color:var(--text); font-weight:500; }
.mb-card-pri {
  font-family:var(--font-m); font-size:.62rem; text-transform:uppercase; padding:2px 6px;
  border-radius:3px; letter-spacing:.04em; white-space:nowrap;
}
.pri-high { background:rgba(239,68,68,.15); color:#ef4444; }
.pri-normal { background:rgba(255,255,255,.05); color:var(--text-muted); }
.pri-low { background:rgba(34,197,94,.1); color:#22c55e; }

.mb-card-meta { display:flex; justify-content:space-between; font-size:.72rem; color:var(--text-muted); }
.mb-card-agent { overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }

.mb-empty { text-align:center; padding:20px 8px; color:var(--text-muted); font-size:.78rem; }

@media (max-width:900px) {
  .mb-board { grid-template-columns:repeat(2, 1fr); }
}
@media (max-width:600px) {
  .mb-board { grid-template-columns:1fr; }
  .mb-header { flex-direction:column; }
}

/* ═══════════════════════════════════════════════════════════════════
   MOBILE POLISH — Touch, Gestures, Landscape
═══════════════════════════════════════════════════════════════════ */

/* Touch feedback for interactive elements */
@media (hover:none) and (pointer:coarse) {
  .side-link, .tab, .btn, .home-action-btn, .cmd-result, .mb-card,
  .widget-card, .agents-card, .fleet-card {
    -webkit-tap-highlight-color: rgba(255,255,255,.08);
  }
  .side-link:active, .tab:active, .btn:active, .home-action-btn:active,
  .cmd-result:active, .mb-card:active {
    transform: scale(.97);
    transition: transform .08s ease;
  }
}

/* Smooth sidebar drawer transition */
.app-sidebar {
  will-change: transform;
  -webkit-overflow-scrolling: touch;
}

/* Full-screen command palette on mobile */
@media (max-width:768px) {
  .cmd-palette { padding-top:0; align-items:stretch; }
  .cmd-palette-box {
    max-width:100vw; width:100vw; margin:0;
    border-radius:0; max-height:100vh; height:100vh;
    display:flex; flex-direction:column;
  }
  .cmd-palette-box .cmd-results { flex:1; overflow-y:auto; }
  #cmd-input { font-size:16px; min-height:48px; } /* Prevent iOS zoom */
  .cmd-result { min-height:48px; padding:12px 16px; }
}

/* Landscape-specific adjustments */
@media (max-height:500px) and (orientation:landscape) {
  .app-hdr { height:40px; }
  .app-sidebar { top:40px; }
  .app-main { margin-top:40px; padding-top:12px; padding-bottom:60px; }
  .app-tabbar { height:44px; }
  .tab { font-size:.42rem; gap:1px; }
  .tab svg { width:16px; height:16px; }
  .home-greeting { padding:8px 0; }
  .home-hello { font-size:1rem; }
  .widget-card { padding:10px; }
}

/* Better widget layout on tablet */
@media (min-width:769px) and (max-width:1024px) {
  .home-widgets { display:grid; grid-template-columns:repeat(2, 1fr); gap:16px; }
  .widget-card[data-widget="stats"] { grid-column:1 / -1; }
}

/* Prevent horizontal overflow everywhere on mobile */
@media (max-width:768px) {
  .app-main { overflow-x:hidden; }
  .home-wrap, .log-wrap, .mb-wrap, .tc-wrap, .wfe-wrap,
  .agents-wrap, .fleet-wrap, .bp-wrap, .ana-wrap,
  .missions-wrap, .comms-wrap { overflow-x:hidden; max-width:100vw; }

  /* Better spacing for mobile stat rings */
  .home-stat-ring .ring-svg { width:56px; height:56px; }

  /* Ensure filter inputs don't overflow */
  .filter-select, .filter-input { max-width:100%; box-sizing:border-box; }

  /* Mission board cards: easier grab on mobile */
  .mb-card { padding:14px; }
  .mb-card-title { font-size:.88rem; }
}

/* ═══════════════════════════════════════════════════════════════════
   QUICK NOTES PANEL
═══════════════════════════════════════════════════════════════════ */
.qn-panel {
  position:fixed; right:-360px; top:52px; bottom:0;
  width:340px; max-width:90vw;
  background:var(--panel-bg, var(--bg));
  border-left:1px solid var(--border);
  z-index:250; display:flex; flex-direction:column;
  transition:right .25s ease;
  backdrop-filter:blur(18px);
}
.qn-panel.open { right:0; }

.qn-header {
  display:flex; justify-content:space-between; align-items:center;
  padding:10px 14px; border-bottom:1px solid var(--border);
}
.qn-title { font-family:var(--font-h); font-size:.85rem; color:var(--text); letter-spacing:.04em; text-transform:uppercase; }
.qn-header-actions { display:flex; gap:6px; }
.qn-btn {
  background:none; border:1px solid var(--border); color:var(--text-muted);
  padding:4px 10px; border-radius:var(--radius); font-size:.72rem;
  cursor:pointer; font-family:var(--font-m); transition:color .15s, border-color .15s;
}
.qn-btn:hover { color:var(--text); border-color:var(--accent); }
.qn-close { font-size:1.1rem; padding:2px 8px; border:none; }

.qn-editor {
  flex:1; resize:none; padding:14px;
  background:transparent; border:none; color:var(--text);
  font-family:var(--font-m); font-size:.82rem; line-height:1.6;
  outline:none;
}
.qn-editor::placeholder { color:var(--text-muted); }

.qn-footer {
  display:flex; justify-content:space-between; padding:8px 14px;
  font-size:.65rem; color:var(--text-muted); font-family:var(--font-m);
  border-top:1px solid var(--border);
}

@media (max-width:480px) {
  .qn-panel { width:100vw; max-width:100vw; }
}

/* ═══════════════════════════════════════════════════════════════════
   FAVORITES / BOOKMARKS
═══════════════════════════════════════════════════════════════════ */
.sidebar-favorites { padding:0 8px; }
.fav-section-label {
  font-family:var(--font-m); font-size:.6rem; text-transform:uppercase;
  letter-spacing:.08em; color:var(--text-muted); padding:8px 12px 4px;
}
.fav-link { position:relative; }
.fav-link .fav-remove {
  display:none; position:absolute; right:6px; top:50%; transform:translateY(-50%);
  background:none; border:none; color:var(--text-muted); cursor:pointer;
  font-size:.9rem; padding:2px 6px; border-radius:var(--radius);
  line-height:1;
}
.fav-link:hover .fav-remove { display:block; }
.fav-link .fav-remove:hover { color:#ef4444; background:rgba(239,68,68,.1); }

/* Favorite button active state (filled star) */
#btn-favorite.active svg { fill:var(--accent); color:var(--accent); }
#btn-favorite { transition:transform .15s; }
#btn-favorite:active { transform:scale(.85); }
