/* ═══════════════════════════════════════════════════════════════════
   ATM — 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;
}

/* ─────────────────────────────────────────────────────────────────
   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; }

/* ─────────────────────────────────────────────────────────────────
   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; }

/* ─────────────────────────────────────────────────────────────────
   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; }
}

/* ─────────────────────────────────────────────────────────────────
   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)); }
}
