/**
 * MySquad v2 Visual Overrides
 * Applies premium design system to existing neighborhood map, command deck, and hub canvas
 * without changing HTML structure or JS functionality.
 */

/* ── Import design system tokens ── */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=Space+Grotesk:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500;600&display=swap');

/* ── Override base CSS variables used by neighborhood_map ── */
:root {
  --bg: #05070a !important;
  --panel: #0a0d12 !important;
  --panel-deep: #06080c !important;
  --surface: #0f131a !important;
  --border: rgba(148, 163, 184, 0.10) !important;
  --text: #e2e8f0 !important;
  --heading: #ffffff !important;
  --dim: #64748b !important;
  --cyan: #22d3ee !important;
  --green: #34d399 !important;
  --orange: #f59e0b !important;
  --purple: #a78bfa !important;
  --gold: #eab308 !important;

  --font-body: 'Inter', system-ui, sans-serif;
  --font-heading: 'Space Grotesk', system-ui, sans-serif;
  --font-mono: 'JetBrains Mono', monospace;
}

/* ── Typography override for deck ── */
body {
  font-family: var(--font-body) !important;
  background: var(--bg) !important;
  color: var(--text) !important;
}

/* ── Top Bar ── */
.topbar {
  background: rgba(5, 7, 10, 0.80) !important;
  backdrop-filter: blur(20px) saturate(1.2) !important;
  -webkit-backdrop-filter: blur(20px) saturate(1.2) !important;
  border-bottom: 1px solid var(--border) !important;
  height: 60px !important;
  padding: 0 20px !important;
}

.nav-logo {
  font-family: var(--font-heading) !important;
  font-size: 1.2rem !important;
  font-weight: 700 !important;
  letter-spacing: -0.02em !important;
  color: #fff !important;
  text-shadow: none !important;
}

/* Hub switcher */
.hub-switcher-btn {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-radius: 8px !important;
  color: var(--text) !important;
  font-family: var(--font-body) !important;
  font-size: 0.8rem !important;
  transition: all 200ms ease !important;
}

.hub-switcher-btn:hover {
  border-color: var(--orange) !important;
  background: rgba(245, 158, 11, 0.08) !important;
}

.hub-switcher-dropdown {
  background: var(--panel) !important;
  border: 1px solid var(--border) !important;
  border-radius: 10px !important;
  box-shadow: 0 12px 40px rgba(0,0,0,0.50) !important;
}

.hub-dropdown-item {
  font-size: 0.82rem !important;
  color: var(--text) !important;
  border-bottom: 1px solid rgba(148,163,184,0.06) !important;
  transition: all 150ms ease !important;
}

.hub-dropdown-item:hover {
  background: var(--surface) !important;
}

.hub-dropdown-item.active {
  background: rgba(245, 158, 11, 0.08) !important;
  border-left: 3px solid var(--orange) !important;
}

/* Progress bar */
.progress-bar-wrap {
  max-width: 380px !important;
}

.progress-bar-label {
  font-size: 0.6rem !important;
  letter-spacing: 0.12em !important;
  color: var(--dim) !important;
}

.progress-bar-track {
  height: 5px !important;
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-radius: 3px !important;
}

.progress-bar-fill {
  background: linear-gradient(90deg, var(--orange), var(--cyan)) !important;
  border-radius: 3px !important;
}

/* Notif button */
.notif-btn {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-radius: 8px !important;
  color: var(--dim) !important;
  transition: all 150ms ease !important;
}

.notif-btn:hover {
  border-color: var(--cyan) !important;
  color: var(--cyan) !important;
}

.notif-badge {
  background: var(--orange) !important;
}

/* ── Left Sidebar ── */
.sidebar {
  background: var(--panel) !important;
  border-right: 1px solid var(--border) !important;
  padding: 14px 0 !important;
  top: 60px !important;
  height: calc(100vh - 60px) !important;
}

.nav-section-label {
  font-size: 0.6rem !important;
  letter-spacing: 0.14em !important;
  color: var(--dim) !important;
  padding: 8px 16px 4px !important;
  text-transform: uppercase !important;
  font-weight: 600 !important;
}

.nav-link {
  font-size: 0.82rem !important;
  color: var(--text-secondary, #94a3b8) !important;
  padding: 8px 16px !important;
  border-left: 2px solid transparent !important;
  transition: all 150ms ease !important;
  font-family: var(--font-body) !important;
}

.nav-link:hover {
  background: var(--surface) !important;
  color: #fff !important;
  border-left-color: var(--orange) !important;
}

.nav-link.active {
  background: rgba(245, 158, 11, 0.08) !important;
  color: var(--orange) !important;
  border-left-color: var(--orange) !important;
}

.nav-sep {
  background: var(--border) !important;
  margin: 8px 16px !important;
}

/* ── Main Content ── */
.main {
  padding: 24px !important;
}

.page-header h1 {
  font-family: var(--font-heading) !important;
  font-size: 1.4rem !important;
  font-weight: 600 !important;
  letter-spacing: -0.01em !important;
  color: #fff !important;
}

.page-header p {
  color: var(--dim) !important;
  font-size: 0.9rem !important;
}

/* ── Garage Cards ── */
.garage-card {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-radius: 12px !important;
  padding: 20px !important;
  transition: all 250ms ease !important;
  box-shadow: none !important;
}

.garage-card:hover {
  border-color: rgba(148,163,184,0.22) !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 12px 40px rgba(0,0,0,0.40) !important;
}

.garage-card::before {
  height: 2px !important;
  background: linear-gradient(90deg, transparent, var(--orange), transparent) !important;
  opacity: 0.6 !important;
}

.garage-card:hover::before {
  opacity: 1 !important;
}

.garage-name {
  font-family: var(--font-heading) !important;
  font-size: 0.95rem !important;
  font-weight: 600 !important;
  letter-spacing: -0.01em !important;
  color: #fff !important;
}

.garage-creator {
  font-size: 0.75rem !important;
  color: var(--dim) !important;
}

.garage-desc {
  font-size: 0.82rem !important;
  color: var(--text-secondary, #94a3b8) !important;
  line-height: 1.55 !important;
}

.garage-tag {
  font-size: 0.62rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.06em !important;
  text-transform: uppercase !important;
  padding: 3px 8px !important;
  background: rgba(255,255,255,0.04) !important;
  border: 1px solid var(--border) !important;
  border-radius: 4px !important;
  color: var(--dim) !important;
}

.garage-tag.featured {
  background: rgba(245, 158, 11, 0.10) !important;
  border-color: rgba(245, 158, 11, 0.25) !important;
  color: var(--orange) !important;
}

.garage-status {
  font-size: 0.6rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.08em !important;
  color: var(--green) !important;
}

.garage-status .dot {
  width: 6px !important;
  height: 6px !important;
  border-radius: 50% !important;
  background: var(--green) !important;
  box-shadow: 0 0 8px var(--green) !important;
}

.peek-btn {
  font-family: var(--font-body) !important;
  font-size: 0.72rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.04em !important;
  padding: 7px 14px !important;
  border: 1px solid var(--border) !important;
  border-radius: 6px !important;
  color: var(--dim) !important;
  transition: all 150ms ease !important;
}

.peek-btn:hover {
  border-color: var(--cyan) !important;
  color: var(--cyan) !important;
  background: rgba(34, 211, 238, 0.06) !important;
}

.garage-members {
  font-size: 0.72rem !important;
  color: var(--dim) !important;
}

/* Category overrides */
.garage-card--cat-trading { --gc-accent: #f97316 !important; --gc-tint: rgba(249, 115, 22, 0.12) !important; --gc-glow: rgba(249, 115, 22, 0.22) !important; }
.garage-card--cat-tech { --gc-accent: #22d3ee !important; --gc-tint: rgba(34, 211, 238, 0.10) !important; --gc-glow: rgba(34, 211, 238, 0.18) !important; }
.garage-card--cat-creative { --gc-accent: #a78bfa !important; --gc-tint: rgba(167, 139, 250, 0.12) !important; --gc-glow: rgba(167, 139, 250, 0.22) !important; }
.garage-card--cat-bluecollar { --gc-accent: #f59e0b !important; --gc-tint: rgba(245, 158, 11, 0.13) !important; --gc-glow: rgba(245, 158, 11, 0.24) !important; }
.garage-card--cat-community { --gc-accent: #34d399 !important; --gc-tint: rgba(52, 211, 153, 0.10) !important; --gc-glow: rgba(52, 211, 153, 0.20) !important; }
.garage-card--cat-other { --gc-accent: #64748b !important; --gc-tint: rgba(100, 116, 139, 0.09) !important; --gc-glow: rgba(100, 116, 139, 0.14) !important; }

/* ── Section headers ── */
.section-title {
  font-family: var(--font-heading) !important;
  font-size: 0.9rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.04em !important;
  color: #fff !important;
}

.section-count {
  font-size: 0.75rem !important;
  color: var(--dim) !important;
}

.featured-label {
  font-size: 0.62rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.12em !important;
  color: var(--orange) !important;
}

/* ── Create Hub Button ── */
.create-hub-btn {
  font-family: var(--font-body) !important;
  font-size: 0.82rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.02em !important;
  background: linear-gradient(135deg, var(--cyan), var(--purple)) !important;
  border-radius: 10px !important;
  box-shadow: 0 4px 16px rgba(34, 211, 238, 0.20) !important;
  transition: all 200ms ease !important;
}

.create-hub-btn:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 8px 24px rgba(34, 211, 238, 0.30) !important;
}

/* ── Right Panel ── */
.right-panel {
  background: var(--panel) !important;
  border-left: 1px solid var(--border) !important;
  padding: 16px !important;
  top: 60px !important;
  height: calc(100vh - 60px) !important;
}

.panel-section-title {
  font-size: 0.6rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.12em !important;
  color: var(--dim) !important;
  border-bottom: 1px solid var(--border) !important;
  padding-bottom: 6px !important;
  text-transform: uppercase !important;
}

/* Chat panel */
.chat-feed {
  background: var(--bg) !important;
  border: 1px solid var(--border) !important;
  border-radius: 8px !important;
  font-size: 0.78rem !important;
}

.chat-msg {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-radius: 6px !important;
}

.chat-msg .msg-user {
  color: var(--cyan) !important;
  font-weight: 600 !important;
  font-size: 0.7rem !important;
}

.chat-input {
  background: var(--bg) !important;
  border: 1px solid var(--border) !important;
  border-radius: 6px !important;
  color: var(--text) !important;
  font-family: var(--font-body) !important;
  font-size: 0.8rem !important;
}

.chat-input:focus {
  border-color: var(--orange) !important;
  outline: none !important;
}

.chat-send {
  background: linear-gradient(135deg, var(--cyan), var(--purple)) !important;
  border: none !important;
  border-radius: 6px !important;
  color: var(--bg) !important;
  font-weight: 700 !important;
  font-size: 0.75rem !important;
}

/* Agent controls */
.agent-control {
  background: var(--bg) !important;
  border: 1px solid var(--border) !important;
  border-radius: 6px !important;
  transition: all 150ms ease !important;
}

.agent-control:hover {
  border-color: var(--purple) !important;
  background: rgba(167, 139, 250, 0.05) !important;
}

.agent-control .ac-name {
  font-size: 0.78rem !important;
  color: #fff !important;
}

/* Compute status */
.compute-row {
  font-size: 0.72rem !important;
  border-bottom: 1px solid var(--border) !important;
}

.compute-label {
  color: var(--dim) !important;
}

.compute-val {
  color: #fff !important;
  font-weight: 600 !important;
}

.compute-val.online {
  color: var(--green) !important;
}

/* ── Map ── */
.nh-map-stage-wrap {
  border: 1px solid var(--border) !important;
  border-radius: 14px !important;
  box-shadow: 0 12px 48px rgba(0,0,0,0.45) !important;
}

.nh-map-toolbar {
  background: rgba(5, 7, 10, 0.90) !important;
  backdrop-filter: blur(12px) !important;
  border: 1px solid var(--border) !important;
  border-radius: 10px !important;
}

.nh-tbtn {
  font-family: var(--font-body) !important;
  font-size: 0.65rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.04em !important;
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-radius: 6px !important;
  color: var(--text) !important;
  transition: all 150ms ease !important;
}

.nh-tbtn:hover {
  border-color: var(--cyan) !important;
  color: #fff !important;
}

.nh-tbtn.active {
  border-color: var(--green) !important;
  color: var(--green) !important;
  box-shadow: 0 0 12px rgba(52, 211, 153, 0.15) !important;
}

.nh-map-watermark {
  font-family: var(--font-mono) !important;
  font-size: 0.65rem !important;
  letter-spacing: 0.3em !important;
  color: rgba(226, 232, 240, 0.25) !important;
}

.nh-pin-label {
  font-family: var(--font-body) !important;
  font-size: 0.75rem !important;
  font-weight: 600 !important;
  background: rgba(0,0,0,0.88) !important;
  border: 1px solid rgba(255,255,255,0.12) !important;
  border-radius: 6px !important;
  color: #fff !important;
  letter-spacing: 0.02em !important;
}

.nh-pin:hover {
  filter: drop-shadow(0 0 12px rgba(245, 158, 11, 0.50)) !important;
}

.nh-pin-garage-btn {
  font-family: var(--font-mono) !important;
  font-size: 0.6rem !important;
  letter-spacing: 0.06em !important;
  background: rgba(0,0,0,0.80) !important;
  border: 1px solid rgba(52, 211, 153, 0.35) !important;
  border-radius: 4px !important;
  color: var(--green) !important;
  transition: all 150ms ease !important;
}

.nh-pin-garage-btn:hover {
  box-shadow: 0 0 10px rgba(52, 211, 153, 0.30) !important;
}

/* ── Garage Dock ── */
.nh-garage-dock {
  background: linear-gradient(180deg, #0a0d12 0%, #06080c 100%) !important;
  border: 1px solid var(--border) !important;
  border-radius: 14px !important;
}

.nh-garage-dock-head {
  background: rgba(0,0,0,0.25) !important;
  border-bottom: 1px solid var(--border) !important;
}

.nh-garage-title {
  font-family: var(--font-heading) !important;
  font-size: 0.95rem !important;
  color: #fff !important;
}

.nh-garage-badge {
  font-size: 0.55rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.1em !important;
  color: var(--cyan) !important;
  border: 1px solid var(--border) !important;
  border-radius: 20px !important;
  padding: 5px 10px !important;
}

.nh-member-lane {
  background: linear-gradient(90deg, rgba(245, 158, 11, 0.05), transparent) !important;
  border-bottom: 1px solid var(--border) !important;
}

.nh-shelf {
  background: repeating-linear-gradient(90deg, var(--surface) 0 2px, var(--panel) 2px 4px) !important;
  border: 1px solid var(--border) !important;
  border-radius: 8px !important;
}

.nh-pegboard {
  background:
    linear-gradient(rgba(0,0,0,0.35), rgba(0,0,0,0.35)),
    repeating-linear-gradient(#131821 0 18px, #0d1118 18px 36px) !important;
  border: 1px solid var(--border) !important;
  border-radius: 8px !important;
}

.nh-tool {
  background: rgba(8, 12, 16, 0.92) !important;
  border: 1px solid var(--border) !important;
  border-radius: 6px !important;
  color: #fff !important;
  font-size: 0.62rem !important;
  transition: all 150ms ease !important;
}

.nh-tool:hover {
  border-color: var(--cyan) !important;
  box-shadow: 0 0 14px rgba(34, 211, 238, 0.20) !important;
  transform: translateY(-2px) !important;
}

/* ── Bridge strip ── */
.nh-bridge-strip {
  top: 60px !important;
  height: 30px !important;
  background: rgba(5, 7, 10, 0.92) !important;
  backdrop-filter: blur(10px) !important;
  border-bottom: 1px solid var(--border) !important;
  font-family: var(--font-body) !important;
}

.nh-morale-chip {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-radius: 8px !important;
  color: var(--text) !important;
  transition: all 200ms ease !important;
}

.nh-morale-chip:hover {
  border-color: var(--orange) !important;
  box-shadow: 0 0 12px rgba(245, 158, 11, 0.12) !important;
}

.nh-morale-label {
  font-family: var(--font-mono) !important;
  font-size: 0.55rem !important;
  letter-spacing: 0.18em !important;
  color: var(--dim) !important;
}

.nh-morale-text {
  font-size: 0.76rem !important;
  color: #fff !important;
}

.nh-bridge-cmd {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-radius: 8px !important;
  color: var(--cyan) !important;
  font-family: var(--font-mono) !important;
  transition: all 150ms ease !important;
}

.nh-bridge-cmd:hover {
  border-color: var(--cyan) !important;
  background: rgba(34, 211, 238, 0.10) !important;
}

/* ── Modal ── */
.modal-overlay {
  background: rgba(0, 0, 0, 0.70) !important;
  backdrop-filter: blur(6px) !important;
}

.modal {
  background: var(--panel) !important;
  border: 1px solid var(--border) !important;
  border-radius: 14px !important;
  box-shadow: 0 20px 60px rgba(0,0,0,0.60) !important;
}

.modal-header {
  border-bottom: 1px solid var(--border) !important;
  padding: 16px 20px !important;
}

.modal-header h2 {
  font-family: var(--font-heading) !important;
  font-size: 1rem !important;
  font-weight: 600 !important;
  color: #fff !important;
  letter-spacing: 0.04em !important;
}

.modal-close {
  background: none !important;
  border: none !important;
  color: var(--dim) !important;
  font-size: 1.3rem !important;
  border-radius: 6px !important;
  transition: all 150ms ease !important;
}

.modal-close:hover {
  background: var(--surface) !important;
  color: #fff !important;
}

.modal-body {
  padding: 18px 20px !important;
}

.form-group label {
  font-size: 0.68rem !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.08em !important;
  color: var(--dim) !important;
}

.form-group input,
.form-group select,
.form-group textarea {
  background: var(--bg) !important;
  border: 1px solid var(--border) !important;
  border-radius: 6px !important;
  color: var(--text) !important;
  font-family: var(--font-body) !important;
  font-size: 0.88rem !important;
  padding: 9px 11px !important;
  outline: none !important;
  transition: all 150ms ease !important;
}

.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  border-color: var(--orange) !important;
  box-shadow: 0 0 0 3px rgba(245, 158, 11, 0.10) !important;
}

.modal-nav {
  border-top: 1px solid var(--border) !important;
  padding: 14px 20px !important;
}

.modal-btn {
  font-family: var(--font-body) !important;
  font-size: 0.75rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.04em !important;
  border-radius: 6px !important;
  padding: 9px 14px !important;
  cursor: pointer !important;
  transition: all 150ms ease !important;
}

.modal-btn.primary {
  background: linear-gradient(135deg, var(--cyan), var(--purple)) !important;
  color: var(--bg) !important;
  border: none !important;
}

.modal-btn.secondary {
  background: transparent !important;
  border: 1px solid var(--border) !important;
  color: var(--dim) !important;
}

.modal-btn.secondary:hover {
  border-color: var(--border-hover) !important;
  color: var(--text) !important;
}

.step-dot {
  background: var(--border) !important;
  transition: all 200ms ease !important;
}

.step-dot.active {
  background: var(--cyan) !important;
  box-shadow: 0 0 8px rgba(34, 211, 238, 0.35) !important;
}

/* ── Footer ── */
.footer-bar {
  background: var(--panel) !important;
  border-top: 1px solid var(--border) !important;
  color: var(--dim) !important;
  font-size: 0.78rem !important;
  padding: 18px !important;
}

.footer-bar .msqd {
  color: var(--orange) !important;
  font-weight: 700 !important;
}

/* ── Toast ── */
.toast {
  background: var(--panel) !important;
  border: 1px solid var(--border) !important;
  border-radius: 8px !important;
  color: var(--text) !important;
  font-size: 0.85rem !important;
  padding: 10px 20px !important;
  bottom: 20px !important;
}

.toast.error {
  border-color: var(--rose, #fb7185) !important;
  color: var(--rose, #fb7185) !important;
}

/* ── Theme overrides ── */
html.theme-neighborhood body {
  background: radial-gradient(ellipse 100% 55% at 50% 100%, rgba(245, 158, 11, 0.05), transparent 52%), var(--bg) !important;
}

html.theme-spaceship body {
  background: radial-gradient(ellipse 90% 50% at 50% 0%, rgba(34, 211, 238, 0.05), transparent 55%), var(--bg) !important;
}

html.theme-spaceship {
  --orange: #22d3ee !important;
}

html.theme-spaceship .nav-logo {
  color: var(--cyan) !important;
  text-shadow: 0 0 20px rgba(34, 211, 238, 0.30) !important;
}

/* ── Deck theme toggle ── */
.nh-theme-mode-pill {
  font-size: 0.6rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.08em !important;
  color: var(--dim) !important;
}

.nh-theme-mode-pill--manual {
  color: var(--orange) !important;
}

html.theme-spaceship .nh-theme-mode-pill--manual {
  color: var(--cyan) !important;
}

.nh-launch-btn {
  font-family: var(--font-body) !important;
  font-size: 0.68rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.06em !important;
  border-radius: 6px !important;
  transition: all 200ms ease !important;
}

html.theme-neighborhood .nh-launch-btn {
  color: #1a120b !important;
  background: linear-gradient(180deg, #f59e0b, #d97706) !important;
  border: 2px solid rgba(26, 18, 11, 0.80) !important;
  box-shadow: 3px 3px 0 rgba(26, 18, 11, 0.60) !important;
}

html.theme-neighborhood .nh-launch-btn:hover {
  transform: translateY(-1px) !important;
  border-color: #ea580c !important;
}

html.theme-spaceship .nh-launch-btn {
  color: #0a0e14 !important;
  background: linear-gradient(90deg, #22d3ee, #67e8f9) !important;
  border: 1px solid rgba(34, 211, 238, 0.80) !important;
  box-shadow: 0 0 14px rgba(34, 211, 238, 0.30) !important;
}

html.theme-spaceship .nh-launch-btn:hover {
  box-shadow: 0 0 22px rgba(34, 211, 238, 0.45) !important;
}

/* ── Command deck frames ── */
.cde-frame-embed {
  background: var(--bg) !important;
  border: 1px solid var(--border) !important;
  border-radius: 10px !important;
}

.cde-frame-title {
  font-family: var(--font-heading) !important;
  font-size: 0.78rem !important;
  color: #fff !important;
}

.cde-frame-link {
  font-size: 0.72rem !important;
  color: var(--cyan) !important;
}

/* ── Responsive ── */
@media(max-width:1100px){
  .page-layout { padding-top: 90px !important; }
  .sidebar { top: 90px !important; height: calc(100vh - 90px) !important; }
  .right-panel { top: 90px !important; height: calc(100vh - 90px) !important; }
  .right-panel.mobile-open {
    background: var(--panel) !important;
    box-shadow: -8px 0 24px rgba(0,0,0,0.40) !important;
  }
}

@media(max-width:800px){
  .sidebar.mobile-open {
    background: var(--panel) !important;
    box-shadow: 8px 0 24px rgba(0,0,0,0.40) !important;
  }
  .topbar { padding: 0 14px !important; }
  .garage-grid { grid-template-columns: 1fr !important; }
}

/* ── HUB CANVAS OVERRIDES ── */
#canvas-topbar {
  background: rgba(5, 7, 10, 0.85) !important;
  backdrop-filter: blur(16px) saturate(1.2) !important;
  -webkit-backdrop-filter: blur(16px) saturate(1.2) !important;
  border-bottom: 1px solid var(--border) !important;
  padding: 10px 20px !important;
}

#canvas-topbar .brand {
  font-family: var(--font-heading) !important;
  font-weight: 700 !important;
  letter-spacing: -0.01em !important;
  color: #fff !important;
}

#canvas-topbar .nav a {
  color: var(--dim) !important;
  font-size: 0.8rem !important;
  font-weight: 500 !important;
  transition: color 150ms ease !important;
}

#canvas-topbar .nav a:hover {
  color: #fff !important;
}

#open-canvas-root {
  background: var(--bg) !important;
}

.oc-toolbar {
  background: var(--panel) !important;
  border-bottom: 1px solid var(--border) !important;
}

.oc-palette button,
.oc-btn {
  font-family: var(--font-body) !important;
  font-size: 0.75rem !important;
  font-weight: 600 !important;
  border-radius: 6px !important;
  transition: all 150ms ease !important;
}

.oc-board {
  background: var(--bg) !important;
}

.oc-inner {
  background: transparent !important;
}

/* Canvas block styling */
.oc-block {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-radius: 10px !important;
  box-shadow: 0 4px 16px rgba(0,0,0,0.30) !important;
  transition: all 200ms ease !important;
}

.oc-block:hover {
  border-color: var(--border-hover) !important;
  box-shadow: 0 8px 24px rgba(0,0,0,0.40) !important;
}

.oc-block--hero {
  background: linear-gradient(135deg, rgba(245,158,11,0.08), rgba(34,211,238,0.05)) !important;
  border-color: rgba(245, 158, 11, 0.20) !important;
}

.oc-block--chat {
  background: var(--surface) !important;
}

/* Modules dropdown + bg picker */
.modules-menu,
.bg-picker-menu {
  background: var(--panel) !important;
  border: 1px solid var(--border) !important;
  border-radius: 10px !important;
  box-shadow: 0 12px 40px rgba(0,0,0,0.45) !important;
  color: var(--text) !important;
}

.modules-menu label,
.bg-picker-menu button {
  color: var(--text) !important;
  font-size: 0.75rem !important;
}

.bg-picker-menu button:hover {
  background: var(--surface) !important;
}

#canvas-theme {
  background: var(--bg) !important;
  border: 1px solid var(--border) !important;
  border-radius: 6px !important;
  color: var(--text) !important;
  font-family: var(--font-body) !important;
  font-size: 0.75rem !important;
}

/* White theme canvas adjustments */
#open-canvas-root.theme-white .oc-board {
  background: #f8fafc !important;
}

#open-canvas-root.theme-white .oc-block {
  background: #fff !important;
  border-color: #e2e8f0 !important;
  color: #0f172a !important;
}

#open-canvas-root.theme-white .oc-toolbar {
  background: #fff !important;
  border-bottom-color: #e2e8f0 !important;
}

/* ═══════════════════════════════════════════════════════════════
   V2.1 PREMIUM ENHANCEMENTS — Added 2026-05-28
   ═══════════════════════════════════════════════════════════════ */

/* ── Premium Card Hover Glow ── */
.garage-card {
  position: relative;
  overflow: hidden;
}

.garage-card::after {
  content: '';
  position: absolute;
  inset: -1px;
  border-radius: inherit;
  padding: 1px;
  background: conic-gradient(from 0deg, transparent 0%, var(--gc-accent, var(--orange)) 20%, transparent 40%, transparent 60%, var(--gc-accent, var(--cyan)) 80%, transparent 100%);
  background-size: 200% 200%;
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  opacity: 0;
  transition: opacity 0.5s ease;
  pointer-events: none;
  animation: msqBorderGlow 4s linear infinite;
}

.garage-card:hover::after {
  opacity: 0.6;
}

/* ── Enhanced Pin Styling ── */
.nh-pin {
  filter: drop-shadow(0 2px 4px rgba(0,0,0,0.5));
  transition: filter 0.3s ease, transform 0.2s ease;
}

.nh-pin:hover {
  filter: drop-shadow(0 0 16px rgba(245, 158, 11, 0.6));
  transform: scale(1.08);
}

/* ── Toolbar Premium ── */
.nh-map-toolbar {
  box-shadow: 0 4px 24px rgba(0,0,0,0.3) !important;
}

.nh-tbtn {
  position: relative;
  overflow: hidden;
}

.nh-tbtn::before {
  content: '';
  position: absolute;
  top: 0; left: -100%;
  width: 100%; height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.05), transparent);
  transition: left 0.6s ease;
}

.nh-tbtn:hover::before {
  left: 100%;
}

/* ── Bridge Strip Enhancement ── */
.nh-bridge-strip {
  box-shadow: 0 2px 12px rgba(0,0,0,0.2) !important;
}

/* ── Chat Panel Premium ── */
.chat-feed {
  box-shadow: inset 0 2px 8px rgba(0,0,0,0.2) !important;
}

.chat-msg {
  transition: all 0.2s ease;
}

.chat-msg:hover {
  border-color: rgba(148, 163, 184, 0.2) !important;
  transform: translateX(2px);
}

/* ── Agent Control Premium ── */
.agent-control {
  position: relative;
  overflow: hidden;
}

.agent-control::before {
  content: '';
  position: absolute;
  top: 0; left: 0;
  width: 3px; height: 100%;
  background: linear-gradient(180deg, var(--purple), transparent);
  opacity: 0;
  transition: opacity 0.3s ease;
}

.agent-control:hover::before {
  opacity: 0.5;
}

/* ── Sidebar Glow on Active ── */
.nav-link.active {
  box-shadow: inset 3px 0 12px rgba(245, 158, 11, 0.06) !important;
}

/* ── Modal Premium ── */
.modal {
  animation: msqModalFloat 0.4s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}

@keyframes msqModalFloat {
  from { opacity: 0; transform: translateY(20px) scale(0.97); }
  to { opacity: 1; transform: translateY(0) scale(1); }
}

/* ── Canvas Block v2.1 ── */
.oc-block {
  position: relative;
}

.oc-block::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.08), transparent);
  opacity: 0;
  transition: opacity 0.3s ease;
}

.oc-block:hover::before {
  opacity: 1;
}

/* ── Empty State Enhancement ── */
.empty-state {
  animation: msqFadeInUp 0.6s ease forwards;
}

/* ── Hub Switcher Glow ── */
.hub-switcher-btn {
  box-shadow: 0 2px 8px rgba(0,0,0,0.15) !important;
}

.hub-switcher-dropdown {
  animation: msqDropdownSlide 0.2s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}

@keyframes msqDropdownSlide {
  from { opacity: 0; transform: translateY(-6px) scale(0.98); }
  to { opacity: 1; transform: translateY(0) scale(1); }
}

/* ── Progress Bar Shimmer ── */
.progress-bar-fill {
  position: relative;
  overflow: hidden;
}

.progress-bar-fill::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.2), transparent);
  animation: msqShimmer 2s infinite;
}

@keyframes msqShimmer {
  0% { transform: translateX(-100%); }
  100% { transform: translateX(100%); }
}

/* ── Notification Badge Pulse ── */
.notif-badge {
  animation: msqBadgePulse 0.5s cubic-bezier(0.34, 1.56, 0.64, 1);
}

@keyframes msqBadgePulse {
  0% { transform: scale(0); }
  60% { transform: scale(1.3); }
  100% { transform: scale(1); }
}

/* ── Garage Dock Premium ── */
.nh-garage-dock {
  box-shadow: 0 20px 60px rgba(0,0,0,0.5) !important;
}

/* ── Member Lane Animation ── */
.nh-member-dot {
  animation: nhMemberWalk 1.2s ease forwards;
}

/* ── Map Stage Vignette ── */
.nh-map-stage {
  position: relative;
}

.nh-map-stage::after {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  border-radius: inherit;
  box-shadow: inset 0 0 60px rgba(0,0,0,0.4);
}
