/* ==========================================================================
   QuickSell — Design System (2026)
   Stripe/Notion warmth + Shopify accent vibrancy.
   Loaded LAST so it wins specificity ties. Targets both legacy markup
   (.stat-card, .section, .top-bar, .sidebar, .bottom-nav-item, ...) and
   new primitives in the .qs-* namespace.
   ========================================================================== */

/* ----------------------------------------------------------
   Tokens
   ---------------------------------------------------------- */
:root {
  /* Brand — vibrant indigo→violet (Shopify-style energy) */
  --qs-brand-50:  #eef2ff;
  --qs-brand-100: #e0e7ff;
  --qs-brand-200: #c7d2fe;
  --qs-brand-300: #a5b4fc;
  --qs-brand-400: #818cf8;
  --qs-brand-500: #6366f1;
  --qs-brand-600: #4f46e5;
  --qs-brand-700: #4338ca;
  --qs-brand-800: #3730a3;
  --qs-brand-900: #312e81;
  --qs-brand: var(--qs-brand-600);
  --qs-brand-soft: var(--qs-brand-50);
  --qs-brand-ring: rgba(99, 102, 241, 0.22);

  /* Secondary accents */
  --qs-violet: #8b5cf6;
  --qs-fuchsia: #d946ef;
  --qs-emerald: #10b981;
  --qs-emerald-soft: #ecfdf5;
  --qs-amber: #f59e0b;
  --qs-amber-soft: #fffbeb;
  --qs-rose: #f43f5e;
  --qs-rose-soft: #fff1f2;
  --qs-sky: #0ea5e9;
  --qs-sky-soft: #f0f9ff;

  /* Warm neutrals — Notion-ish off-white surface */
  --qs-bg:        #f7f8fc;          /* page canvas */
  --qs-bg-soft:   #fafbfd;          /* nested panels */
  --qs-surface:   #ffffff;          /* cards */
  --qs-surface-2: #f8f9fc;          /* hover/striped */
  --qs-overlay:   rgba(15, 23, 42, 0.55);

  --qs-ink-900: #0b1020;            /* primary text */
  --qs-ink-800: #111827;
  --qs-ink-700: #1f2937;
  --qs-ink-600: #374151;
  --qs-ink-500: #4b5563;            /* secondary text */
  --qs-ink-400: #6b7280;            /* muted text */
  --qs-ink-300: #9ca3af;            /* placeholder */
  --qs-ink-200: #d1d5db;
  --qs-ink-100: #e5e7eb;
  --qs-ink-50:  #f3f4f6;

  --qs-line:    #e8eaf0;            /* default border */
  --qs-line-soft: #eef0f5;
  --qs-line-strong: #d6dae4;

  /* Status palette */
  --qs-success: var(--qs-emerald);
  --qs-success-soft: var(--qs-emerald-soft);
  --qs-warning: var(--qs-amber);
  --qs-warning-soft: var(--qs-amber-soft);
  --qs-danger:  var(--qs-rose);
  --qs-danger-soft: var(--qs-rose-soft);
  --qs-info:    var(--qs-sky);
  --qs-info-soft: var(--qs-sky-soft);

  /* Radii — soft & friendly */
  --qs-r-xs: 4px;
  --qs-r-sm: 6px;
  --qs-r:    10px;
  --qs-r-md: 12px;
  --qs-r-lg: 16px;
  --qs-r-xl: 20px;
  --qs-r-2xl: 28px;
  --qs-r-full: 9999px;

  /* Spacing scale (4px) */
  --qs-s-1:  4px;
  --qs-s-2:  8px;
  --qs-s-3:  12px;
  --qs-s-4:  16px;
  --qs-s-5:  20px;
  --qs-s-6:  24px;
  --qs-s-7:  32px;
  --qs-s-8:  40px;
  --qs-s-9:  56px;
  --qs-s-10: 72px;

  /* Shadows — soft, layered */
  --qs-shadow-xs: 0 1px 2px rgba(15, 23, 42, 0.04);
  --qs-shadow-sm: 0 1px 2px rgba(15, 23, 42, 0.05), 0 1px 3px rgba(15, 23, 42, 0.04);
  --qs-shadow:    0 2px 4px rgba(15, 23, 42, 0.05), 0 4px 12px rgba(15, 23, 42, 0.05);
  --qs-shadow-md: 0 6px 16px rgba(15, 23, 42, 0.07), 0 2px 6px rgba(15, 23, 42, 0.04);
  --qs-shadow-lg: 0 14px 32px rgba(15, 23, 42, 0.10), 0 4px 10px rgba(15, 23, 42, 0.05);
  --qs-shadow-xl: 0 28px 56px rgba(15, 23, 42, 0.14), 0 12px 24px rgba(15, 23, 42, 0.06);
  --qs-shadow-card: 0 0 0 1px rgba(15, 23, 42, 0.04), 0 1px 2px rgba(15, 23, 42, 0.04);
  --qs-shadow-card-hover: 0 0 0 1px rgba(99, 102, 241, 0.18), 0 12px 28px rgba(99, 102, 241, 0.10);
  --qs-shadow-modal: 0 32px 80px rgba(15, 23, 42, 0.22), 0 12px 24px rgba(15, 23, 42, 0.08);
  --qs-shadow-pop:   0 12px 28px rgba(15, 23, 42, 0.12), 0 0 0 1px rgba(15, 23, 42, 0.04);
  --qs-shadow-press: inset 0 1px 2px rgba(15, 23, 42, 0.08);

  /* Gradients */
  --qs-gradient-brand: linear-gradient(135deg, #6366f1 0%, #8b5cf6 50%, #d946ef 100%);
  --qs-gradient-brand-soft: linear-gradient(135deg, #eef2ff 0%, #f5f3ff 100%);
  --qs-gradient-emerald: linear-gradient(135deg, #10b981 0%, #34d399 100%);
  --qs-gradient-amber: linear-gradient(135deg, #f59e0b 0%, #fbbf24 100%);
  --qs-gradient-rose: linear-gradient(135deg, #f43f5e 0%, #fb7185 100%);
  --qs-gradient-sky: linear-gradient(135deg, #0ea5e9 0%, #38bdf8 100%);
  --qs-gradient-page: radial-gradient(1200px 600px at -10% -20%, rgba(99,102,241,0.06), transparent 60%),
                      radial-gradient(900px 600px at 110% 110%, rgba(217,70,239,0.05), transparent 60%);

  /* Glassy header */
  --qs-glass: rgba(255, 255, 255, 0.78);
  --qs-glass-strong: rgba(255, 255, 255, 0.92);

  /* Typography */
  --qs-font-sans: 'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
  --qs-font-mono: ui-monospace, SFMono-Regular, 'SF Mono', Menlo, Consolas, monospace;
  --qs-fz-xs:  0.75rem;     /* 12 */
  --qs-fz-sm:  0.8125rem;   /* 13 */
  --qs-fz-base: 0.9375rem;  /* 15 */
  --qs-fz-md:  1rem;        /* 16 */
  --qs-fz-lg:  1.125rem;    /* 18 */
  --qs-fz-xl:  1.375rem;    /* 22 */
  --qs-fz-2xl: 1.75rem;     /* 28 */
  --qs-fz-3xl: 2.25rem;     /* 36 */
  --qs-track-tight: -0.018em;
  --qs-track-tighter: -0.024em;

  /* Motion */
  --qs-ease: cubic-bezier(0.22, 1, 0.36, 1);
  --qs-ease-out: cubic-bezier(0.16, 1, 0.3, 1);
  --qs-ease-spring: cubic-bezier(0.34, 1.56, 0.64, 1);
  --qs-dur-1: 120ms;
  --qs-dur-2: 200ms;
  --qs-dur-3: 320ms;
  --qs-dur-4: 480ms;

  /* Layout */
  --qs-sidebar-w: 248px;
  --qs-sidebar-w-collapsed: 72px;
  --qs-topbar-h: 60px;
  --qs-bottomnav-h: calc(64px + env(safe-area-inset-bottom, 0px));

  /* Z layers */
  --qs-z-bg: 0;
  --qs-z-base: 1;
  --qs-z-sticky: 50;
  --qs-z-nav: 80;
  --qs-z-overlay: 100;
  --qs-z-sheet: 110;
  --qs-z-modal: 120;
  --qs-z-toast: 200;
}

/* ----------------------------------------------------------
   Bridge legacy variables → new tokens
   so existing dashboard.css/admin.css rules pick up new colors
   without us having to touch them.
   ---------------------------------------------------------- */
:root {
  --color-primary: var(--qs-brand);
  --color-primary-hover: var(--qs-brand-700);
  --color-primary-light: var(--qs-brand-soft);
  --color-primary-soft: var(--qs-brand-soft);
  --color-primary-50: rgba(99, 102, 241, 0.06);
  --color-primary-100: rgba(99, 102, 241, 0.12);
  --color-primary-ring: var(--qs-brand-ring);
  --color-accent: var(--qs-violet);
  --color-accent-soft: #f5f3ff;

  --color-white: var(--qs-surface);
  --color-gray-50:  var(--qs-ink-50);
  --color-gray-100: var(--qs-ink-100);
  --color-gray-200: var(--qs-ink-200);
  --color-gray-300: var(--qs-ink-300);
  --color-gray-400: var(--qs-ink-400);
  --color-gray-500: var(--qs-ink-500);
  --color-gray-600: var(--qs-ink-600);
  --color-gray-700: var(--qs-ink-700);
  --color-gray-800: var(--qs-ink-800);
  --color-gray-900: var(--qs-ink-900);

  --color-success: var(--qs-success);
  --color-success-light: var(--qs-success-soft);
  --color-danger: var(--qs-danger);
  --color-danger-light: var(--qs-danger-soft);
  --color-warning: var(--qs-warning);
  --color-warning-light: var(--qs-warning-soft);

  --shadow-xs: var(--qs-shadow-xs);
  --shadow-sm: var(--qs-shadow-sm);
  --shadow:    var(--qs-shadow);
  --shadow-md: var(--qs-shadow-md);
  --shadow-lg: var(--qs-shadow-lg);
  --shadow-xl: var(--qs-shadow-xl);
  --shadow-card: var(--qs-shadow-card);
  --shadow-card-hover: var(--qs-shadow-card-hover);
  --shadow-modal: var(--qs-shadow-modal);
  --shadow-dropdown: var(--qs-shadow-pop);

  --radius-sm: var(--qs-r-sm);
  --radius:    var(--qs-r);
  --radius-md: var(--qs-r-md);
  --radius-lg: var(--qs-r-lg);
  --radius-xl: var(--qs-r-lg);
  --radius-2xl: var(--qs-r-xl);
  --radius-full: var(--qs-r-full);

  --header-bg: var(--qs-glass);
  --header-bg-mobile: var(--qs-glass-strong);
  --page-bg: var(--qs-bg);
  --header-height: var(--qs-topbar-h);
}

/* ----------------------------------------------------------
   Page canvas / typography baseline
   ---------------------------------------------------------- */
html, body {
  font-family: var(--qs-font-sans) !important;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  font-feature-settings: 'cv11', 'ss01', 'ss03';
  letter-spacing: var(--qs-track-tight);
  color: var(--qs-ink-800);
}

body {
  background-color: var(--qs-bg) !important;
  background-image: var(--qs-gradient-page) !important;
  background-attachment: fixed;
}

.main-content,
.admin-main {
  background: transparent !important;
}

.view {
  scroll-behavior: smooth;
  animation: qs-view-in var(--qs-dur-3) var(--qs-ease-out);
}

@keyframes qs-view-in {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: translateY(0); }
}

::selection { background: var(--qs-brand-100); color: var(--qs-brand-800); }

/* ----------------------------------------------------------
   Brand mark (text gradient + glow)
   ---------------------------------------------------------- */
.brand h2,
.qs-brand-text {
  background: var(--qs-gradient-brand);
  -webkit-background-clip: text;
          background-clip: text;
  -webkit-text-fill-color: transparent;
  font-weight: 700;
  letter-spacing: var(--qs-track-tighter);
}

.brand-icon {
  color: var(--qs-brand) !important;
  filter: drop-shadow(0 6px 14px rgba(99, 102, 241, 0.35));
}

/* ----------------------------------------------------------
   Sidebar — desktop rail / mobile drawer
   ---------------------------------------------------------- */
.sidebar,
.admin-sidebar {
  background: var(--qs-surface) !important;
  border-right: 1px solid var(--qs-line) !important;
  box-shadow: none !important;
  width: var(--qs-sidebar-w) !important;
}

.sidebar-header {
  padding: 18px 20px !important;
  border-bottom: 1px solid var(--qs-line-soft) !important;
}

.sidebar-nav {
  padding: 10px 12px !important;
  gap: 2px !important;
}

.sidebar-nav-section {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--qs-ink-400);
  padding: 14px 12px 6px;
}

.nav-item {
  position: relative;
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  padding: 9px 12px !important;
  border-radius: var(--qs-r-md) !important;
  font-weight: 500 !important;
  font-size: var(--qs-fz-sm) !important;
  color: var(--qs-ink-600) !important;
  transition: background var(--qs-dur-1) var(--qs-ease),
              color var(--qs-dur-1) var(--qs-ease),
              transform var(--qs-dur-2) var(--qs-ease-out) !important;
  background: transparent !important;
  border: none !important;
  text-decoration: none !important;
  cursor: pointer;
}

.nav-item:hover {
  background: var(--qs-ink-50) !important;
  color: var(--qs-ink-900) !important;
}

.nav-item.active {
  background: linear-gradient(180deg, var(--qs-brand-50), #f5f3ff) !important;
  color: var(--qs-brand-700) !important;
  font-weight: 600 !important;
  box-shadow: inset 0 0 0 1px rgba(99, 102, 241, 0.16);
}

.nav-item.active::before {
  content: '';
  position: absolute;
  left: -12px;
  top: 8px; bottom: 8px;
  width: 3px;
  border-radius: 0 3px 3px 0;
  background: var(--qs-gradient-brand);
}

.nav-item .nav-icon { color: inherit !important; flex: 0 0 auto; }

.nav-item .badge,
.nav-badge {
  background: var(--qs-gradient-brand) !important;
  color: #fff !important;
  border: none !important;
  font-weight: 700 !important;
  font-size: 10.5px !important;
  padding: 2px 7px !important;
  border-radius: var(--qs-r-full) !important;
  box-shadow: 0 4px 10px rgba(99, 102, 241, 0.35);
  margin-left: auto !important;
}

.sidebar-footer {
  border-top: 1px solid var(--qs-line-soft) !important;
  padding: 10px 12px !important;
}

.logout-btn {
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  padding: 9px 12px !important;
  border-radius: var(--qs-r-md) !important;
  font-weight: 500 !important;
  color: var(--qs-ink-600) !important;
  background: transparent !important;
  border: none !important;
  cursor: pointer;
  width: 100%;
  font-size: var(--qs-fz-sm);
  transition: background var(--qs-dur-1) var(--qs-ease), color var(--qs-dur-1) var(--qs-ease);
}

.logout-btn:hover {
  background: var(--qs-rose-soft) !important;
  color: var(--qs-rose) !important;
}

/* ----------------------------------------------------------
   Top bar (desktop) — clean glassy header
   ---------------------------------------------------------- */
.top-bar,
.admin-header {
  background: var(--qs-glass) !important;
  -webkit-backdrop-filter: saturate(180%) blur(16px);
          backdrop-filter: saturate(180%) blur(16px);
  border-bottom: 1px solid rgba(15, 23, 42, 0.06) !important;
  box-shadow: none !important;
  height: var(--qs-topbar-h) !important;
  padding: 0 24px !important;
  position: sticky !important;
  top: 0;
  z-index: var(--qs-z-sticky) !important;
}

#viewTitle {
  font-size: 1.0625rem !important;
  font-weight: 650 !important;
  letter-spacing: var(--qs-track-tight);
  color: var(--qs-ink-900) !important;
}

.user-info {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  font-size: var(--qs-fz-sm) !important;
  line-height: 1.25;
}

.user-business {
  font-weight: 600 !important;
  color: var(--qs-ink-900) !important;
}

#userEmail, #adminEmail {
  color: var(--qs-ink-400) !important;
}

.role-badge {
  background: var(--qs-brand-soft);
  color: var(--qs-brand-700);
  padding: 2px 8px;
  border-radius: var(--qs-r-full);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

/* Channel selector pill */
.channel-selector {
  display: flex;
  align-items: center;
  gap: 8px;
}

.channel-select-wrapper { position: relative; }

#currentChannel {
  appearance: none;
  -webkit-appearance: none;
  background: var(--qs-surface);
  border: 1px solid var(--qs-line);
  border-radius: var(--qs-r-full);
  padding: 7px 32px 7px 14px;
  font-size: var(--qs-fz-sm);
  font-weight: 500;
  color: var(--qs-ink-800);
  box-shadow: var(--qs-shadow-xs);
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");
  background-repeat: no-repeat;
  background-position: right 12px center;
  transition: border-color var(--qs-dur-1) var(--qs-ease), box-shadow var(--qs-dur-1) var(--qs-ease);
}

#currentChannel:hover { border-color: var(--qs-line-strong); }
#currentChannel:focus { border-color: var(--qs-brand); box-shadow: 0 0 0 4px var(--qs-brand-ring); outline: none; }

.channel-unread-dot {
  position: absolute;
  top: -2px; right: -2px;
  width: 9px; height: 9px;
  border-radius: var(--qs-r-full);
  background: var(--qs-rose);
  box-shadow: 0 0 0 2px var(--qs-surface), 0 4px 10px rgba(244, 63, 94, 0.4);
}

/* Connect dropdown */
.connect-dropdown { position: relative; }

.connect-menu {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  min-width: 220px;
  background: var(--qs-surface);
  border: 1px solid var(--qs-line);
  border-radius: var(--qs-r-md);
  box-shadow: var(--qs-shadow-pop);
  padding: 6px;
  z-index: var(--qs-z-overlay);
  animation: qs-pop-in var(--qs-dur-2) var(--qs-ease-out);
}

.connect-menu button {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  padding: 9px 10px;
  background: transparent;
  border: none;
  border-radius: var(--qs-r);
  text-align: left;
  font-size: var(--qs-fz-sm);
  font-weight: 500;
  color: var(--qs-ink-700);
  cursor: pointer;
  transition: background var(--qs-dur-1) var(--qs-ease);
}

.connect-menu button:hover {
  background: var(--qs-ink-50);
  color: var(--qs-ink-900);
}

@keyframes qs-pop-in {
  from { opacity: 0; transform: translateY(-4px) scale(0.98); }
  to   { opacity: 1; transform: translateY(0)    scale(1); }
}

/* ----------------------------------------------------------
   Buttons (.btn .btn-primary .btn-secondary .btn-small)
   ---------------------------------------------------------- */
.btn,
.btn-primary {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px;
  padding: 10px 16px !important;
  border: none !important;
  border-radius: var(--qs-r-md) !important;
  font-weight: 600 !important;
  font-size: var(--qs-fz-sm) !important;
  letter-spacing: -0.005em;
  background: var(--qs-gradient-brand) !important;
  color: #fff !important;
  cursor: pointer;
  box-shadow: 0 6px 16px rgba(99, 102, 241, 0.28),
              inset 0 1px 0 rgba(255, 255, 255, 0.18);
  transition: transform var(--qs-dur-2) var(--qs-ease-out),
              box-shadow var(--qs-dur-2) var(--qs-ease-out),
              filter var(--qs-dur-2) var(--qs-ease-out);
}

.btn:hover,
.btn-primary:hover {
  transform: translateY(-1px);
  box-shadow: 0 12px 28px rgba(99, 102, 241, 0.36),
              inset 0 1px 0 rgba(255, 255, 255, 0.22);
  filter: saturate(115%);
}

.btn:active,
.btn-primary:active { transform: translateY(0); }

.btn-secondary {
  background: var(--qs-surface) !important;
  color: var(--qs-ink-800) !important;
  border: 1px solid var(--qs-line) !important;
  box-shadow: var(--qs-shadow-xs) !important;
}

.btn-secondary:hover {
  background: var(--qs-ink-50) !important;
  border-color: var(--qs-line-strong) !important;
  transform: none;
}

.btn-small {
  padding: 6px 12px !important;
  font-size: var(--qs-fz-xs) !important;
  border-radius: var(--qs-r) !important;
  background: var(--qs-surface) !important;
  color: var(--qs-ink-800) !important;
  border: 1px solid var(--qs-line) !important;
  box-shadow: var(--qs-shadow-xs) !important;
  font-weight: 600 !important;
}

.btn-small:hover {
  background: var(--qs-ink-50) !important;
  border-color: var(--qs-line-strong) !important;
}

/* QS button primitives (new) */
.qs-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 10px 16px;
  border-radius: var(--qs-r-md);
  font-family: inherit;
  font-size: var(--qs-fz-sm);
  font-weight: 600;
  line-height: 1.2;
  border: 1px solid transparent;
  cursor: pointer;
  transition: transform var(--qs-dur-2) var(--qs-ease-out),
              box-shadow var(--qs-dur-2) var(--qs-ease-out),
              background var(--qs-dur-1) var(--qs-ease),
              border-color var(--qs-dur-1) var(--qs-ease),
              color var(--qs-dur-1) var(--qs-ease);
  user-select: none;
  white-space: nowrap;
}

.qs-btn:focus-visible { outline: none; box-shadow: 0 0 0 4px var(--qs-brand-ring); }
.qs-btn:disabled { opacity: 0.55; cursor: not-allowed; transform: none !important; }

.qs-btn--primary {
  background: var(--qs-gradient-brand);
  color: #fff;
  box-shadow: 0 6px 16px rgba(99, 102, 241, 0.28), inset 0 1px 0 rgba(255,255,255,0.18);
}
.qs-btn--primary:hover { transform: translateY(-1px); box-shadow: 0 12px 28px rgba(99, 102, 241, 0.36); filter: saturate(115%); }
.qs-btn--primary:active { transform: translateY(0); }

.qs-btn--secondary {
  background: var(--qs-surface);
  color: var(--qs-ink-800);
  border-color: var(--qs-line);
  box-shadow: var(--qs-shadow-xs);
}
.qs-btn--secondary:hover { background: var(--qs-ink-50); border-color: var(--qs-line-strong); }

.qs-btn--ghost { background: transparent; color: var(--qs-ink-700); }
.qs-btn--ghost:hover { background: var(--qs-ink-50); color: var(--qs-ink-900); }

.qs-btn--danger {
  background: var(--qs-rose);
  color: #fff;
  box-shadow: 0 6px 16px rgba(244, 63, 94, 0.28);
}
.qs-btn--danger:hover { background: #e11d48; }

.qs-btn--success {
  background: var(--qs-emerald);
  color: #fff;
  box-shadow: 0 6px 16px rgba(16, 185, 129, 0.28);
}
.qs-btn--success:hover { background: #059669; }

.qs-btn--sm { padding: 6px 12px; font-size: var(--qs-fz-xs); }
.qs-btn--lg { padding: 12px 20px; font-size: var(--qs-fz-base); }
.qs-btn--icon { padding: 8px; width: 36px; height: 36px; }
.qs-btn--block { width: 100%; }

/* Icon button */
.qs-icon-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px; height: 36px;
  border-radius: var(--qs-r);
  background: transparent;
  color: var(--qs-ink-600);
  border: none;
  cursor: pointer;
  transition: background var(--qs-dur-1) var(--qs-ease), color var(--qs-dur-1) var(--qs-ease);
}
.qs-icon-btn:hover { background: var(--qs-ink-50); color: var(--qs-ink-900); }
.qs-icon-btn:focus-visible { outline: none; box-shadow: 0 0 0 4px var(--qs-brand-ring); }

/* ----------------------------------------------------------
   Inputs
   ---------------------------------------------------------- */
input[type='text'],
input[type='email'],
input[type='password'],
input[type='number'],
input[type='search'],
input[type='tel'],
input[type='url'],
input[type='date'],
input[type='time'],
select,
textarea {
  font-family: inherit !important;
  font-size: var(--qs-fz-sm) !important;
  border: 1px solid var(--qs-line) !important;
  border-radius: var(--qs-r-md) !important;
  background: var(--qs-surface) !important;
  color: var(--qs-ink-900) !important;
  padding: 9px 12px !important;
  transition: border-color var(--qs-dur-1) var(--qs-ease),
              box-shadow var(--qs-dur-1) var(--qs-ease),
              background var(--qs-dur-1) var(--qs-ease) !important;
}

input:hover, select:hover, textarea:hover { border-color: var(--qs-line-strong) !important; }

input:focus, select:focus, textarea:focus {
  outline: none !important;
  border-color: var(--qs-brand) !important;
  box-shadow: 0 0 0 4px var(--qs-brand-ring) !important;
}

input::placeholder, textarea::placeholder { color: var(--qs-ink-300); }

label { color: var(--qs-ink-700); font-weight: 500; font-size: var(--qs-fz-sm); }

/* QS form primitives */
.qs-field { display: flex; flex-direction: column; gap: 6px; }
.qs-field-label { font-size: var(--qs-fz-sm); font-weight: 600; color: var(--qs-ink-700); }
.qs-field-hint  { font-size: var(--qs-fz-xs); color: var(--qs-ink-400); }
.qs-field-error { font-size: var(--qs-fz-xs); color: var(--qs-danger); }

.qs-input,
.qs-select,
.qs-textarea {
  width: 100%;
  font-family: inherit;
  font-size: var(--qs-fz-sm);
  padding: 9px 12px;
  border: 1px solid var(--qs-line);
  border-radius: var(--qs-r-md);
  background: var(--qs-surface);
  color: var(--qs-ink-900);
  transition: border-color var(--qs-dur-1) var(--qs-ease), box-shadow var(--qs-dur-1) var(--qs-ease);
}

.qs-input:focus, .qs-select:focus, .qs-textarea:focus {
  outline: none;
  border-color: var(--qs-brand);
  box-shadow: 0 0 0 4px var(--qs-brand-ring);
}

/* Search input */
.qs-search {
  position: relative;
  display: flex;
  align-items: center;
}
.qs-search input {
  padding-left: 38px !important;
  background: var(--qs-bg-soft) !important;
}
.qs-search-icon {
  position: absolute;
  left: 12px;
  color: var(--qs-ink-400);
  pointer-events: none;
}

/* ----------------------------------------------------------
   Cards & sections
   ---------------------------------------------------------- */
.card,
.metric-card,
.stat-card,
.analytics-card,
.product-card,
.order-card,
.qs-card {
  background: var(--qs-surface) !important;
  border: 1px solid var(--qs-line) !important;
  border-radius: var(--qs-r-lg) !important;
  box-shadow: var(--qs-shadow-card) !important;
  transition: box-shadow var(--qs-dur-3) var(--qs-ease-out),
              transform var(--qs-dur-3) var(--qs-ease-out),
              border-color var(--qs-dur-3) var(--qs-ease) !important;
}

.qs-card { padding: var(--qs-s-5); }

.card:hover,
.metric-card:hover,
.stat-card:hover,
.product-card:hover,
.qs-card--hover:hover {
  box-shadow: var(--qs-shadow-card-hover) !important;
  border-color: rgba(99, 102, 241, 0.18) !important;
  transform: translateY(-2px);
}

.qs-card--flush { padding: 0; }
.qs-card-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 20px;
  border-bottom: 1px solid var(--qs-line-soft);
  gap: 12px;
}
.qs-card-title {
  font-size: var(--qs-fz-base);
  font-weight: 650;
  color: var(--qs-ink-900);
  letter-spacing: var(--qs-track-tight);
}
.qs-card-subtitle { font-size: var(--qs-fz-xs); color: var(--qs-ink-400); }
.qs-card-body { padding: 20px; }
.qs-card-footer {
  padding: 14px 20px;
  border-top: 1px solid var(--qs-line-soft);
  display: flex; align-items: center; justify-content: flex-end; gap: 8px;
}

/* Section heading */
.section { margin-top: var(--qs-s-7); }
.section h2,
.qs-section-title {
  font-size: var(--qs-fz-lg) !important;
  font-weight: 650 !important;
  letter-spacing: var(--qs-track-tight);
  color: var(--qs-ink-900) !important;
  margin: 0 0 var(--qs-s-4) !important;
}

/* Stats grid (legacy) */
.stats-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)) !important;
  gap: var(--qs-s-4) !important;
  margin-bottom: var(--qs-s-7) !important;
}

.stat-card {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 18px !important;
  border-radius: var(--qs-r-lg) !important;
  background: linear-gradient(180deg, var(--qs-surface) 0%, var(--qs-bg-soft) 100%) !important;
}

.stat-icon {
  width: 44px; height: 44px;
  border-radius: var(--qs-r-md);
  background: var(--qs-brand-soft);
  color: var(--qs-brand);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  box-shadow: inset 0 0 0 1px rgba(99, 102, 241, 0.1);
}
.stat-icon-orders   { background: var(--qs-emerald-soft); color: var(--qs-emerald); box-shadow: inset 0 0 0 1px rgba(16,185,129,0.12); }
.stat-icon-pending  { background: var(--qs-amber-soft); color: var(--qs-amber); box-shadow: inset 0 0 0 1px rgba(245,158,11,0.14); }
.stat-icon-pages    { background: #dbeafe; color: #1d4ed8; box-shadow: inset 0 0 0 1px rgba(29,78,216,0.12); }
.stat-icon-messages { background: #ecfeff; color: #0e7490; box-shadow: inset 0 0 0 1px rgba(14,116,144,0.12); }
.stat-icon-trials   { background: var(--qs-amber-soft); color: var(--qs-amber); }
.stat-icon-courier  { background: #fef3c7; color: #b45309; box-shadow: inset 0 0 0 1px rgba(180,83,9,0.12); }

.stat-info, .stat-content { display: flex; flex-direction: column; gap: 2px; }

.stat-info h3,
.stat-content .stat-value {
  font-size: var(--qs-fz-2xl) !important;
  font-weight: 700 !important;
  letter-spacing: var(--qs-track-tighter);
  color: var(--qs-ink-900) !important;
  line-height: 1.1;
}

.stat-info p,
.stat-content h3 {
  font-size: var(--qs-fz-xs) !important;
  color: var(--qs-ink-500) !important;
  font-weight: 500 !important;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin: 0;
}

.stat-detail {
  font-size: var(--qs-fz-xs);
  color: var(--qs-ink-500);
  margin-top: 2px;
}
.stat-detail .active { color: var(--qs-emerald); font-weight: 600; }

/* ----------------------------------------------------------
   Tables
   ---------------------------------------------------------- */
table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  background: var(--qs-surface);
  border-radius: var(--qs-r-lg);
  overflow: hidden;
}

table thead th {
  background: var(--qs-bg-soft) !important;
  color: var(--qs-ink-500) !important;
  font-weight: 600 !important;
  font-size: 11px !important;
  letter-spacing: 0.06em !important;
  text-transform: uppercase !important;
  padding: 10px 14px !important;
  border-bottom: 1px solid var(--qs-line) !important;
  text-align: left;
}

table tbody td {
  padding: 12px 14px !important;
  border-bottom: 1px solid var(--qs-line-soft) !important;
  font-size: var(--qs-fz-sm);
  color: var(--qs-ink-800);
}

table tbody tr {
  transition: background var(--qs-dur-1) var(--qs-ease);
}

table tbody tr:hover {
  background: var(--qs-brand-50);
}

/* QS table primitive */
.qs-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
}
.qs-table th, .qs-table td { padding: 12px 16px; text-align: left; }
.qs-table thead th {
  background: var(--qs-bg-soft);
  color: var(--qs-ink-500);
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  font-weight: 600;
  border-bottom: 1px solid var(--qs-line);
}
.qs-table tbody tr { transition: background var(--qs-dur-1) var(--qs-ease); }
.qs-table tbody tr:hover { background: var(--qs-bg-soft); }
.qs-table tbody td { border-bottom: 1px solid var(--qs-line-soft); font-size: var(--qs-fz-sm); }

/* ----------------------------------------------------------
   Badges / pills
   ---------------------------------------------------------- */
.badge,
.status-badge,
.tag,
.qs-pill {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-weight: 600 !important;
  font-size: var(--qs-fz-xs) !important;
  letter-spacing: -0.005em !important;
  border-radius: var(--qs-r-full) !important;
  padding: 3px 10px !important;
  background: var(--qs-ink-50);
  color: var(--qs-ink-700);
  border: 1px solid var(--qs-line);
  white-space: nowrap;
}

.qs-pill--brand   { background: var(--qs-brand-50); color: var(--qs-brand-700); border-color: rgba(99,102,241,0.18); }
.qs-pill--success { background: var(--qs-success-soft); color: var(--qs-emerald); border-color: rgba(16,185,129,0.2); }
.qs-pill--warning { background: var(--qs-warning-soft); color: #b45309; border-color: rgba(245,158,11,0.24); }
.qs-pill--danger  { background: var(--qs-danger-soft); color: var(--qs-rose); border-color: rgba(244,63,94,0.22); }
.qs-pill--info    { background: var(--qs-info-soft); color: #0369a1; border-color: rgba(14,165,233,0.22); }
.qs-pill--neutral { background: var(--qs-ink-50); color: var(--qs-ink-700); }

/* Order/status badges (legacy variants) */
.status-pending   { background: var(--qs-amber-soft) !important; color: #b45309 !important; }
.status-confirmed { background: var(--qs-info-soft) !important; color: #0369a1 !important; }
.status-shipped   { background: var(--qs-brand-50) !important; color: var(--qs-brand-700) !important; }
.status-delivered { background: var(--qs-success-soft) !important; color: var(--qs-emerald) !important; }
.status-cancelled { background: var(--qs-danger-soft) !important; color: var(--qs-rose) !important; }

/* ----------------------------------------------------------
   Empty states
   ---------------------------------------------------------- */
.empty-state,
.qs-empty {
  text-align: center;
  padding: 48px 24px;
  color: var(--qs-ink-400) !important;
  font-size: var(--qs-fz-sm);
}

.qs-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  background: var(--qs-bg-soft);
  border: 1px dashed var(--qs-line);
  border-radius: var(--qs-r-lg);
}

.qs-empty-icon {
  width: 56px; height: 56px;
  border-radius: var(--qs-r-full);
  display: flex; align-items: center; justify-content: center;
  background: var(--qs-surface);
  color: var(--qs-brand);
  box-shadow: var(--qs-shadow-sm);
}
.qs-empty-title { color: var(--qs-ink-800); font-weight: 600; font-size: var(--qs-fz-base); }
.qs-empty-text  { color: var(--qs-ink-400); font-size: var(--qs-fz-sm); max-width: 380px; }

/* ----------------------------------------------------------
   Tabs (segmented + underlined variants)
   ---------------------------------------------------------- */
.qs-segmented {
  display: inline-flex;
  background: var(--qs-ink-50);
  border-radius: var(--qs-r-md);
  padding: 4px;
  gap: 2px;
  border: 1px solid var(--qs-line-soft);
}
.qs-segmented button {
  appearance: none;
  background: transparent;
  border: none;
  font-family: inherit;
  font-size: var(--qs-fz-sm);
  font-weight: 600;
  color: var(--qs-ink-500);
  padding: 7px 14px;
  border-radius: var(--qs-r);
  cursor: pointer;
  transition: background var(--qs-dur-1) var(--qs-ease), color var(--qs-dur-1) var(--qs-ease), box-shadow var(--qs-dur-1) var(--qs-ease);
}
.qs-segmented button:hover { color: var(--qs-ink-800); }
.qs-segmented button.is-active {
  background: var(--qs-surface);
  color: var(--qs-ink-900);
  box-shadow: var(--qs-shadow-xs), 0 0 0 1px var(--qs-line);
}

.qs-tabs {
  display: flex;
  gap: 2px;
  border-bottom: 1px solid var(--qs-line);
}
.qs-tabs button {
  appearance: none;
  background: transparent;
  border: none;
  font-family: inherit;
  font-size: var(--qs-fz-sm);
  font-weight: 600;
  color: var(--qs-ink-500);
  padding: 12px 14px;
  cursor: pointer;
  border-bottom: 2px solid transparent;
  transition: color var(--qs-dur-1) var(--qs-ease), border-color var(--qs-dur-1) var(--qs-ease);
}
.qs-tabs button:hover { color: var(--qs-ink-800); }
.qs-tabs button.is-active {
  color: var(--qs-brand-700);
  border-bottom-color: var(--qs-brand);
}

/* ----------------------------------------------------------
   Modals (legacy + .qs-modal)
   ---------------------------------------------------------- */
.modal-content,
.modal,
.qs-modal {
  border-radius: var(--qs-r-xl) !important;
  box-shadow: var(--qs-shadow-modal) !important;
  border: 1px solid rgba(15, 23, 42, 0.05) !important;
  background: var(--qs-surface) !important;
}

.qs-modal-overlay {
  position: fixed; inset: 0;
  background: var(--qs-overlay);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  z-index: var(--qs-z-modal);
  display: flex; align-items: center; justify-content: center;
  padding: 16px;
  animation: qs-fade-in var(--qs-dur-2) var(--qs-ease-out);
}
.qs-modal {
  width: 100%;
  max-width: 540px;
  max-height: calc(100vh - 32px);
  display: flex; flex-direction: column;
  overflow: hidden;
  animation: qs-modal-in var(--qs-dur-3) var(--qs-ease-spring);
}

@keyframes qs-fade-in { from { opacity: 0; } to { opacity: 1; } }
@keyframes qs-modal-in {
  from { opacity: 0; transform: translateY(12px) scale(0.96); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}

/* ----------------------------------------------------------
   Bottom-sheet (mobile native-app feel)
   ---------------------------------------------------------- */
.qs-sheet-overlay {
  position: fixed; inset: 0;
  background: var(--qs-overlay);
  z-index: var(--qs-z-sheet);
  animation: qs-fade-in var(--qs-dur-2) var(--qs-ease-out);
}
.qs-sheet {
  position: fixed;
  left: 0; right: 0; bottom: 0;
  background: var(--qs-surface);
  border-radius: var(--qs-r-xl) var(--qs-r-xl) 0 0;
  box-shadow: var(--qs-shadow-xl);
  z-index: calc(var(--qs-z-sheet) + 1);
  padding: 14px 16px calc(20px + env(safe-area-inset-bottom, 0px));
  max-height: 86vh;
  overflow: auto;
  animation: qs-sheet-in var(--qs-dur-3) var(--qs-ease-spring);
}
.qs-sheet::before {
  content: '';
  display: block;
  width: 38px; height: 4px;
  border-radius: 999px;
  background: var(--qs-ink-100);
  margin: 0 auto 12px;
}
@keyframes qs-sheet-in {
  from { transform: translateY(100%); }
  to   { transform: translateY(0); }
}

/* ----------------------------------------------------------
   Trial banner
   ---------------------------------------------------------- */
.trial-banner {
  background: var(--qs-gradient-brand) !important;
  color: #fff !important;
  border: none !important;
  font-weight: 500 !important;
  letter-spacing: -0.005em;
  padding: 10px 16px !important;
}

.trial-banner.warning  { background: var(--qs-gradient-amber) !important; }
.trial-banner.expired  { background: var(--qs-gradient-rose) !important; }
.trial-banner.paid     { background: var(--qs-gradient-emerald) !important; }

.trial-upgrade-btn {
  background: rgba(255, 255, 255, 0.18) !important;
  color: #fff !important;
  border: 1px solid rgba(255, 255, 255, 0.32) !important;
  border-radius: var(--qs-r-full) !important;
  padding: 5px 14px !important;
  font-weight: 600 !important;
  font-size: var(--qs-fz-xs) !important;
  backdrop-filter: blur(4px);
  transition: background var(--qs-dur-1) var(--qs-ease);
}

.trial-upgrade-btn:hover { background: rgba(255, 255, 255, 0.28) !important; }

/* ----------------------------------------------------------
   Bottom navigation (mobile/tablet)
   ---------------------------------------------------------- */
.mobile-bottom-nav,
.bottom-nav {
  background: var(--qs-glass-strong) !important;
  -webkit-backdrop-filter: saturate(180%) blur(20px);
          backdrop-filter: saturate(180%) blur(20px);
  border-top: 1px solid rgba(15, 23, 42, 0.06) !important;
  box-shadow: 0 -8px 24px rgba(15, 23, 42, 0.06) !important;
  padding-bottom: env(safe-area-inset-bottom, 0px) !important;
}

.bottom-nav-item {
  position: relative;
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 4px;
  padding: 8px 4px;
  background: transparent !important;
  border: none !important;
  color: var(--qs-ink-400) !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  cursor: pointer;
  transition: color var(--qs-dur-1) var(--qs-ease), transform var(--qs-dur-1) var(--qs-ease);
}

.bottom-nav-item span { letter-spacing: 0; }

.bottom-nav-item:active { transform: scale(0.94); }

.bottom-nav-item.active {
  color: var(--qs-brand-700) !important;
}
.bottom-nav-item.active::before {
  content: '';
  position: absolute;
  top: 4px;
  width: 36px; height: 28px;
  background: var(--qs-brand-50);
  border-radius: var(--qs-r-full);
  z-index: -1;
}

.bottom-nav-item .nav-badge {
  position: absolute;
  top: 2px;
  right: 22%;
  font-size: 9.5px !important;
  padding: 1px 5px !important;
  min-width: 16px;
  text-align: center;
}

/* ----------------------------------------------------------
   Plan distribution + admin specific
   ---------------------------------------------------------- */
.plan-distribution {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 14px;
}
.plan-stat {
  background: var(--qs-surface);
  border: 1px solid var(--qs-line);
  border-radius: var(--qs-r-lg);
  padding: 18px;
  text-align: center;
  transition: transform var(--qs-dur-2) var(--qs-ease-out), box-shadow var(--qs-dur-2) var(--qs-ease-out);
}
.plan-stat:hover { transform: translateY(-2px); box-shadow: var(--qs-shadow-card-hover); }
.plan-stat .count {
  font-size: var(--qs-fz-2xl);
  font-weight: 700;
  background: var(--qs-gradient-brand);
  -webkit-background-clip: text;
          background-clip: text;
  -webkit-text-fill-color: transparent;
  letter-spacing: var(--qs-track-tighter);
}
.plan-stat .name {
  text-transform: uppercase;
  font-size: var(--qs-fz-xs);
  font-weight: 600;
  letter-spacing: 0.08em;
  color: var(--qs-ink-500);
  margin-top: 4px;
}

.activity-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.activity-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 16px;
  background: var(--qs-surface);
  border: 1px solid var(--qs-line);
  border-radius: var(--qs-r-md);
  font-size: var(--qs-fz-sm);
}
.activity-action { color: var(--qs-ink-800); font-weight: 500; }
.activity-time   { color: var(--qs-ink-400); font-size: var(--qs-fz-xs); }

/* ----------------------------------------------------------
   Scrollbars
   ---------------------------------------------------------- */
* { scrollbar-width: thin; scrollbar-color: var(--qs-ink-200) transparent; }
::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb {
  background: var(--qs-ink-200);
  border-radius: 999px;
  border: 2px solid transparent;
  background-clip: padding-box;
}
::-webkit-scrollbar-thumb:hover { background: var(--qs-ink-300); background-clip: padding-box; border: 2px solid transparent; }

/* ----------------------------------------------------------
   Focus visibility
   ---------------------------------------------------------- */
button:focus-visible,
a:focus-visible,
[role='button']:focus-visible {
  outline: none;
  box-shadow: 0 0 0 4px var(--qs-brand-ring);
  border-radius: var(--qs-r);
}

/* ----------------------------------------------------------
   Helpers
   ---------------------------------------------------------- */
.qs-text-gradient {
  background: var(--qs-gradient-brand);
  -webkit-background-clip: text;
          background-clip: text;
  -webkit-text-fill-color: transparent;
}

.qs-stack { display: flex; flex-direction: column; gap: var(--qs-s-3); }
.qs-stack--lg { gap: var(--qs-s-5); }
.qs-row { display: flex; align-items: center; gap: var(--qs-s-3); }
.qs-row--between { display: flex; align-items: center; justify-content: space-between; gap: var(--qs-s-3); }
.qs-grid-2 { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--qs-s-4); }
.qs-grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--qs-s-4); }
.qs-grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--qs-s-4); }
@media (max-width: 900px) {
  .qs-grid-3, .qs-grid-4 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 560px) {
  .qs-grid-2, .qs-grid-3, .qs-grid-4 { grid-template-columns: 1fr; }
}

.qs-skeleton {
  background: linear-gradient(90deg, var(--qs-ink-50) 0%, var(--qs-ink-100) 50%, var(--qs-ink-50) 100%);
  background-size: 200% 100%;
  border-radius: var(--qs-r);
  animation: qs-shimmer 1.4s infinite linear;
}
@keyframes qs-shimmer {
  0%   { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

/* ----------------------------------------------------------
   Mobile / tablet — native app feel
   ---------------------------------------------------------- */
@media (max-width: 1024px) {
  .top-bar {
    padding: 0 16px !important;
    background: var(--qs-glass-strong) !important;
  }
  #viewTitle {
    font-size: 1.0625rem !important;
  }
  .user-info { display: none !important; }
  .stats-grid { gap: 12px !important; }
  .stat-card { padding: 14px !important; }
  .stat-info h3,
  .stat-content .stat-value { font-size: 1.5rem !important; }
}

@media (max-width: 720px) {
  body { background: var(--qs-bg) !important; background-image: none !important; }

  .top-bar {
    height: 56px !important;
    padding: 0 12px !important;
    padding-top: env(safe-area-inset-top, 0px) !important;
  }

  /* Larger app-style title */
  #viewTitle {
    font-size: 1.125rem !important;
    font-weight: 700 !important;
    letter-spacing: var(--qs-track-tight);
  }

  .channel-selector { gap: 6px; }
  #currentChannel {
    max-width: 140px;
    font-size: 12.5px;
    padding: 6px 28px 6px 10px;
  }

  /* Hide secondary chrome on phones — sidebar is drawer-only */
  .sidebar {
    position: fixed !important;
    inset: 0 auto 0 0;
    transform: translateX(-100%);
    transition: transform var(--qs-dur-3) var(--qs-ease-out);
    width: 280px !important;
    z-index: var(--qs-z-overlay);
    box-shadow: var(--qs-shadow-xl) !important;
  }
  .sidebar.open { transform: translateX(0); }

  /* Page padding tightened, big touch targets */
  .view {
    padding: 14px !important;
    padding-bottom: calc(var(--qs-bottomnav-h) + 14px) !important;
  }

  .stats-grid { grid-template-columns: 1fr 1fr !important; gap: 10px !important; }

  /* Cards lose hover-lift on touch (no hover, plus jittery) */
  .card:hover, .stat-card:hover, .product-card:hover, .qs-card--hover:hover {
    transform: none !important;
  }

  /* Tap feedback for nav items */
  .nav-item:active, .bottom-nav-item:active { transform: scale(0.97); }
}

/* Tablet — 2-col stats, sidebar visible at 720+ but condensed */
@media (min-width: 721px) and (max-width: 1024px) {
  .stats-grid { grid-template-columns: repeat(2, 1fr) !important; }
}

/* Touch-only refinements */
@media (hover: none) {
  .card:hover, .stat-card:hover, .product-card:hover { transform: none !important; box-shadow: var(--qs-shadow-card) !important; }
  .nav-item:hover, .bottom-nav-item:hover { background: transparent !important; }
}

/* Reduce motion */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}

/* ----------------------------------------------------------
   Admin shell tinting (subtle violet shift)
   ---------------------------------------------------------- */
.admin-container {
  --qs-brand: #7c3aed;
  --qs-brand-soft: #f5f3ff;
  --qs-brand-ring: rgba(124, 58, 237, 0.22);
  --qs-gradient-brand: linear-gradient(135deg, #7c3aed 0%, #a855f7 50%, #d946ef 100%);
}

.admin-container .role-badge {
  background: linear-gradient(135deg, #f5f3ff, #fae8ff);
  color: #6d28d9;
  border: 1px solid rgba(124, 58, 237, 0.18);
}

/* ==========================================================================
   Sidebar — collapsible rail + grouped sections
   ========================================================================== */
.qs-sidebar {
  display: flex;
  flex-direction: column;
  width: var(--qs-sidebar-w);
  transition: width var(--qs-dur-3) var(--qs-ease-out);
}

.qs-sidebar.is-collapsed { width: var(--qs-sidebar-w-collapsed) !important; }

/* Header: brand + collapse toggle */
.qs-sidebar-header {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 16px 14px !important;
  border-bottom: 1px solid var(--qs-line-soft) !important;
  position: relative;
}

.qs-brand-link {
  display: flex;
  align-items: center;
  gap: 10px;
  text-decoration: none !important;
  color: inherit !important;
  flex: 1;
  min-width: 0;
}

.qs-brand-mark {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: var(--qs-r-md);
  background: var(--qs-gradient-brand-soft);
  border: 1px solid rgba(99, 102, 241, 0.16);
  flex-shrink: 0;
}

.qs-sidebar-collapse {
  margin-left: auto;
  flex-shrink: 0;
}

.qs-sidebar-close {
  display: none;
}

.qs-sidebar.is-collapsed .qs-brand-link h2,
.qs-sidebar.is-collapsed .qs-nav-label,
.qs-sidebar.is-collapsed .qs-nav-group-title,
.qs-sidebar.is-collapsed .badge {
  display: none !important;
}

.qs-sidebar.is-collapsed .qs-sidebar-header { justify-content: center; padding: 16px 8px !important; }
.qs-sidebar.is-collapsed .qs-sidebar-collapse { margin-left: 0; }
.qs-sidebar.is-collapsed .qs-brand-link { justify-content: center; }
.qs-sidebar.is-collapsed .nav-item { justify-content: center !important; padding: 10px !important; }
.qs-sidebar.is-collapsed .logout-btn { justify-content: center !important; padding: 10px !important; }
.qs-sidebar.is-collapsed .qs-nav-group { padding-top: 8px; }

/* Nav: grouped sections */
.qs-sidebar-nav {
  flex: 1;
  overflow-y: auto;
  padding: 12px !important;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.qs-nav-group { padding-bottom: 10px; }

.qs-nav-group-title {
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--qs-ink-300);
  padding: 12px 10px 6px;
  user-select: none;
}

.qs-nav-group .nav-item {
  width: 100%;
  text-align: left;
}

/* Mobile drawer behavior is handled in the responsive section above; ensure
   close button is visible only on mobile. */
@media (max-width: 720px) {
  .qs-sidebar-close { display: inline-flex !important; position: absolute; right: 8px; top: 8px; }
  .qs-sidebar-collapse { display: none !important; }
  .qs-sidebar.is-collapsed { width: 280px !important; } /* Drawer mode ignores collapsed */
  .qs-sidebar.is-collapsed .qs-brand-link h2,
  .qs-sidebar.is-collapsed .qs-nav-label,
  .qs-sidebar.is-collapsed .qs-nav-group-title,
  .qs-sidebar.is-collapsed .badge { display: initial !important; }
  .qs-sidebar.is-collapsed .nav-item,
  .qs-sidebar.is-collapsed .logout-btn { justify-content: flex-start !important; padding: 9px 12px !important; }
}

/* Pin footer to bottom */
.qs-sidebar-footer {
  margin-top: auto;
}

/* When collapsed, shrink the legacy --sidebar-width var so .main-content's
   margin-left and the .dashboard-container layout follow the rail width. */
:root { --sidebar-width: var(--qs-sidebar-w); }

html[data-sidebar='collapsed'] {
  --sidebar-width: var(--qs-sidebar-w-collapsed);
}

/* On mobile the sidebar is a drawer (position:fixed transform:translateX),
   so main-content should NOT reserve space for it. Reset the legacy var. */
@media (max-width: 720px) {
  html[data-sidebar='collapsed'],
  html[data-sidebar='expanded'] {
    --sidebar-width: 0px;
  }
}

/* ==========================================================================
   TopBar — refined header
   ========================================================================== */
.qs-topbar {
  display: flex !important;
  align-items: center !important;
  gap: 12px;
}

.qs-topbar-title {
  font-size: 1rem !important;
  font-weight: 650 !important;
  letter-spacing: var(--qs-track-tight);
  color: var(--qs-ink-900) !important;
  margin: 0;
  flex-shrink: 0;
}

.qs-topbar-channel {
  margin-left: auto;
  display: flex;
  align-items: center;
  gap: 8px;
}

.qs-topbar-connect { padding: 7px 12px !important; }

.qs-topbar-bell {
  position: relative;
  margin-left: 4px;
}
.qs-bell-dot {
  position: absolute;
  top: 8px; right: 9px;
  width: 7px; height: 7px;
  border-radius: var(--qs-r-full);
  background: var(--qs-rose);
  box-shadow: 0 0 0 2px var(--qs-glass-strong), 0 0 8px rgba(244, 63, 94, 0.6);
}

/* User menu trigger */
.qs-user-menu { position: relative; }

.qs-user-trigger {
  display: flex !important;
  align-items: center;
  gap: 10px;
  background: transparent;
  border: 1px solid transparent;
  border-radius: var(--qs-r-md);
  padding: 4px 8px 4px 4px;
  cursor: pointer;
  font-family: inherit;
  transition: background var(--qs-dur-1) var(--qs-ease), border-color var(--qs-dur-1) var(--qs-ease);
  max-width: 240px;
}
.qs-user-trigger:hover { background: var(--qs-ink-50); border-color: var(--qs-line); }
.qs-user-trigger:focus-visible { outline: none; box-shadow: 0 0 0 4px var(--qs-brand-ring); }

.qs-avatar {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px; height: 32px;
  border-radius: var(--qs-r-full);
  background: var(--qs-gradient-brand);
  color: #fff;
  font-weight: 700;
  font-size: var(--qs-fz-xs);
  letter-spacing: 0.02em;
  flex-shrink: 0;
  box-shadow: 0 4px 10px rgba(99, 102, 241, 0.30);
}
.qs-avatar--lg { width: 40px; height: 40px; font-size: var(--qs-fz-sm); }

.qs-user-text {
  display: flex !important;
  flex-direction: column;
  align-items: flex-start !important;
  line-height: 1.2;
  text-align: left;
  min-width: 0;
}
.qs-user-text .user-business {
  font-size: var(--qs-fz-sm);
  font-weight: 600;
  color: var(--qs-ink-900);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 160px;
}
.qs-user-text #userEmail {
  font-size: 11.5px;
  color: var(--qs-ink-400);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 160px;
}
.qs-user-caret { color: var(--qs-ink-400); flex-shrink: 0; }

/* User popover */
.qs-user-popover {
  position: absolute;
  top: calc(100% + 6px);
  right: 0;
  width: 240px;
  background: var(--qs-surface);
  border: 1px solid var(--qs-line);
  border-radius: var(--qs-r-md);
  box-shadow: var(--qs-shadow-pop);
  padding: 6px;
  z-index: var(--qs-z-overlay);
  animation: qs-pop-in var(--qs-dur-2) var(--qs-ease-out);
}

.qs-user-popover-head {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px;
  border-bottom: 1px solid var(--qs-line-soft);
  margin-bottom: 4px;
}

.qs-user-name {
  font-size: var(--qs-fz-sm);
  font-weight: 650;
  color: var(--qs-ink-900);
}
.qs-user-mail {
  font-size: var(--qs-fz-xs);
  color: var(--qs-ink-400);
  word-break: break-all;
}

.qs-user-popover-item {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  padding: 9px 12px;
  background: transparent;
  border: none;
  border-radius: var(--qs-r);
  text-align: left;
  font-size: var(--qs-fz-sm);
  font-weight: 500;
  color: var(--qs-ink-700);
  cursor: pointer;
  transition: background var(--qs-dur-1) var(--qs-ease);
}
.qs-user-popover-item:hover { background: var(--qs-ink-50); color: var(--qs-ink-900); }
.qs-user-popover-item--danger { color: var(--qs-rose); }
.qs-user-popover-item--danger:hover { background: var(--qs-rose-soft); color: var(--qs-rose); }

/* Show/hide helpers */
.qs-mobile-only { display: none !important; }

@media (max-width: 1024px) {
  .qs-mobile-only { display: inline-flex !important; }
  .qs-user-menu { display: none !important; }
}
@media (max-width: 720px) {
  .qs-topbar-title {
    font-size: 1.0625rem !important;
    font-weight: 700 !important;
    flex: 0 1 auto;
    min-width: 0;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
  }
  .qs-topbar-channel { gap: 6px; }
  .qs-topbar-connect .btn-text { display: none; }
  .qs-topbar-connect { padding: 7px 9px !important; }
  .qs-topbar-bell { width: 34px; height: 34px; }
}

/* ==========================================================================
   More sheet (mobile bottom-nav overflow)
   ========================================================================== */
.qs-more-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 4px 4px 12px;
  border-bottom: 1px solid var(--qs-line-soft);
  margin-bottom: 8px;
}
.qs-more-title {
  font-size: var(--qs-fz-md);
  font-weight: 700;
  color: var(--qs-ink-900);
  letter-spacing: var(--qs-track-tight);
}

.qs-more-list {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.qs-more-item {
  display: flex;
  align-items: center;
  gap: 14px;
  width: 100%;
  padding: 12px 8px;
  background: transparent;
  border: none;
  border-radius: var(--qs-r-md);
  text-align: left;
  cursor: pointer;
  transition: background var(--qs-dur-1) var(--qs-ease);
  font-family: inherit;
}
.qs-more-item:active { background: var(--qs-ink-50); transform: scale(0.99); }
.qs-more-item.is-active { background: var(--qs-brand-50); }

.qs-more-icon {
  width: 40px; height: 40px;
  border-radius: var(--qs-r-md);
  background: var(--qs-bg-soft);
  color: var(--qs-brand-700);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  border: 1px solid var(--qs-line);
}
.qs-more-item.is-active .qs-more-icon {
  background: var(--qs-gradient-brand);
  color: #fff;
  border-color: transparent;
  box-shadow: 0 4px 12px rgba(99, 102, 241, 0.32);
}

.qs-more-text { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.qs-more-label {
  font-size: var(--qs-fz-base);
  font-weight: 600;
  color: var(--qs-ink-900);
  letter-spacing: var(--qs-track-tight);
}
.qs-more-desc {
  font-size: var(--qs-fz-xs);
  color: var(--qs-ink-400);
}

.qs-more-logout {
  margin-top: 12px;
  color: var(--qs-rose) !important;
  border-top: 1px solid var(--qs-line-soft);
  border-radius: 0;
  padding-top: 14px !important;
}
.qs-more-logout:hover { background: var(--qs-rose-soft) !important; }

/* ==========================================================================
   Overview page: hero, KPI grid, order rows, quick actions
   ========================================================================== */
.qs-overview { display: flex; flex-direction: column; gap: 24px; }

.qs-page-hero {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 24px;
  padding: 24px 28px;
  border-radius: var(--qs-r-xl);
  background:
    radial-gradient(800px 280px at 0% 0%, rgba(99, 102, 241, 0.08), transparent 60%),
    radial-gradient(600px 280px at 100% 100%, rgba(217, 70, 239, 0.07), transparent 60%),
    linear-gradient(180deg, var(--qs-surface), var(--qs-bg-soft));
  border: 1px solid var(--qs-line-soft);
}

.qs-page-eyebrow {
  font-size: var(--qs-fz-xs);
  font-weight: 600;
  color: var(--qs-ink-400);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  margin: 0 0 4px;
}

.qs-page-title {
  font-size: var(--qs-fz-2xl);
  font-weight: 800;
  letter-spacing: var(--qs-track-tighter);
  color: var(--qs-ink-900);
  margin: 0 0 6px;
  background: linear-gradient(135deg, var(--qs-ink-900) 0%, var(--qs-brand-700) 100%);
  -webkit-background-clip: text;
          background-clip: text;
  -webkit-text-fill-color: transparent;
}

.qs-page-sub {
  font-size: var(--qs-fz-sm);
  color: var(--qs-ink-500);
  margin: 0;
  max-width: 520px;
}

.qs-page-hero-actions {
  display: flex;
  gap: 8px;
  flex-shrink: 0;
}

/* KPI grid */
.qs-kpi-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
}

.qs-kpi {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 18px;
  background: var(--qs-surface);
  border: 1px solid var(--qs-line);
  border-radius: var(--qs-r-lg);
  box-shadow: var(--qs-shadow-card);
  position: relative;
  overflow: hidden;
  transition: transform var(--qs-dur-2) var(--qs-ease-out), box-shadow var(--qs-dur-2) var(--qs-ease-out);
}
.qs-kpi:hover { transform: translateY(-2px); box-shadow: var(--qs-shadow-card-hover); }

.qs-kpi::before {
  content: '';
  position: absolute;
  top: 0; left: 0;
  width: 100%; height: 3px;
  background: var(--qs-gradient-brand);
  opacity: 0.85;
}

.qs-kpi--emerald::before { background: var(--qs-gradient-emerald); }
.qs-kpi--amber::before   { background: var(--qs-gradient-amber); }
.qs-kpi--sky::before     { background: var(--qs-gradient-sky); }
.qs-kpi--fuchsia::before { background: linear-gradient(135deg, #d946ef, #f472b6); }

.qs-kpi-icon {
  width: 38px; height: 38px;
  border-radius: var(--qs-r);
  display: flex; align-items: center; justify-content: center;
  background: var(--qs-brand-soft);
  color: var(--qs-brand-700);
  flex-shrink: 0;
}
.qs-kpi--emerald .qs-kpi-icon { background: var(--qs-emerald-soft); color: var(--qs-emerald); }
.qs-kpi--amber   .qs-kpi-icon { background: var(--qs-amber-soft); color: #b45309; }
.qs-kpi--sky     .qs-kpi-icon { background: var(--qs-sky-soft); color: #0369a1; }
.qs-kpi--fuchsia .qs-kpi-icon { background: #fdf4ff; color: #a21caf; }

.qs-kpi-body { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.qs-kpi-label {
  font-size: var(--qs-fz-xs);
  font-weight: 600;
  color: var(--qs-ink-500);
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.qs-kpi-value {
  font-size: 1.625rem;
  font-weight: 800;
  letter-spacing: var(--qs-track-tighter);
  color: var(--qs-ink-900);
  line-height: 1.1;
}
.qs-kpi-hint { font-size: var(--qs-fz-xs); color: var(--qs-ink-400); margin-top: 2px; }

/* Two-column layout: orders + quick actions */
.qs-overview-grid {
  display: grid;
  grid-template-columns: 1.6fr 1fr;
  gap: 16px;
}

.qs-overview-orders-list {
  display: flex;
  flex-direction: column;
}

.qs-order-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  width: 100%;
  padding: 14px 20px;
  background: transparent;
  border: none;
  border-bottom: 1px solid var(--qs-line-soft);
  text-align: left;
  cursor: pointer;
  transition: background var(--qs-dur-1) var(--qs-ease);
  font-family: inherit;
}
.qs-order-row:last-child { border-bottom: none; }
.qs-order-row:hover { background: var(--qs-bg-soft); }

.qs-order-row-main { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.qs-order-num {
  font-size: var(--qs-fz-sm);
  font-weight: 700;
  color: var(--qs-ink-900);
  letter-spacing: var(--qs-track-tight);
}
.qs-order-customer {
  font-size: var(--qs-fz-sm);
  color: var(--qs-ink-700);
}
.qs-order-product {
  font-size: var(--qs-fz-xs);
  color: var(--qs-ink-400);
}

.qs-order-row-meta {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-shrink: 0;
}
.qs-order-total {
  font-size: var(--qs-fz-sm);
  font-weight: 700;
  color: var(--qs-emerald);
}

/* Quick actions */
.qs-quick-list { display: flex; flex-direction: column; gap: 4px; }

.qs-quick-row {
  display: flex;
  align-items: center;
  gap: 12px;
  width: 100%;
  padding: 11px 12px;
  background: transparent;
  border: 1px solid transparent;
  border-radius: var(--qs-r-md);
  text-align: left;
  cursor: pointer;
  transition: background var(--qs-dur-1) var(--qs-ease), border-color var(--qs-dur-1) var(--qs-ease);
  font-family: inherit;
}
.qs-quick-row:hover {
  background: var(--qs-bg-soft);
  border-color: var(--qs-line);
}

.qs-quick-icon {
  width: 36px; height: 36px;
  border-radius: var(--qs-r);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.qs-quick-icon--brand   { background: var(--qs-brand-soft); color: var(--qs-brand-700); }
.qs-quick-icon--emerald { background: var(--qs-emerald-soft); color: var(--qs-emerald); }
.qs-quick-icon--amber   { background: var(--qs-amber-soft); color: #b45309; }
.qs-quick-icon--sky     { background: var(--qs-sky-soft); color: #0369a1; }

.qs-quick-text { display: flex; flex-direction: column; min-width: 0; flex: 1; }
.qs-quick-label {
  font-size: var(--qs-fz-sm);
  font-weight: 600;
  color: var(--qs-ink-900);
}
.qs-quick-desc {
  font-size: var(--qs-fz-xs);
  color: var(--qs-ink-400);
}
.qs-quick-arrow { color: var(--qs-ink-300); flex-shrink: 0; }

/* Responsive */
@media (max-width: 1100px) {
  .qs-kpi-grid { grid-template-columns: repeat(2, 1fr); }
  .qs-overview-grid { grid-template-columns: 1fr; }
}
@media (max-width: 720px) {
  .qs-page-hero {
    flex-direction: column;
    align-items: flex-start;
    padding: 20px;
    gap: 16px;
  }
  .qs-page-title { font-size: 1.5rem; }
  .qs-page-hero-actions { width: 100%; }
  .qs-page-hero-actions .qs-btn { flex: 1; justify-content: center; }
  .qs-kpi-grid { gap: 10px; }
  .qs-kpi { padding: 14px; }
  .qs-kpi-value { font-size: 1.4rem; }
}

/* ==========================================================================
   Page toolbar (view-header / search-box / header-actions) — legacy markup
   ========================================================================== */
.view-header {
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  margin-bottom: var(--qs-s-5) !important;
  padding: 12px 16px !important;
  background: var(--qs-surface) !important;
  border: 1px solid var(--qs-line) !important;
  border-radius: var(--qs-r-lg) !important;
  box-shadow: var(--qs-shadow-card) !important;
  flex-wrap: wrap;
}

.view-header > h2,
.view-header > h1 {
  font-size: var(--qs-fz-lg) !important;
  font-weight: 650 !important;
  letter-spacing: var(--qs-track-tight);
  color: var(--qs-ink-900) !important;
  margin: 0 !important;
  flex-shrink: 0;
}

.search-box {
  position: relative;
  flex: 1;
  min-width: 220px;
  max-width: 480px;
}
.search-box .search-icon {
  position: absolute !important;
  left: 12px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--qs-ink-400) !important;
  pointer-events: none;
}
.search-box input {
  padding-left: 38px !important;
  background: var(--qs-bg-soft) !important;
  width: 100%;
  border-radius: var(--qs-r-full) !important;
  border-color: var(--qs-line-soft) !important;
}
.search-box input:focus {
  background: var(--qs-surface) !important;
}

.header-actions {
  display: flex !important;
  gap: 8px !important;
  margin-left: auto;
  flex-shrink: 0;
}

/* Filter row / pill row */
.filter-row, .filters-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: var(--qs-s-4);
}

@media (max-width: 720px) {
  .view-header { padding: 10px 12px !important; gap: 8px !important; }
  .search-box { min-width: 0; }
  .view-header > h2 { font-size: var(--qs-fz-md) !important; width: 100%; }
  .header-actions { margin-left: 0; width: 100%; }
  .header-actions .btn-primary, .header-actions .btn-secondary { flex: 1; justify-content: center; }
}

/* ==========================================================================
   Product card — modernized
   ========================================================================== */
.products-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)) !important;
  gap: 16px !important;
}

.product-card {
  background: var(--qs-surface) !important;
  border: 1px solid var(--qs-line) !important;
  border-radius: var(--qs-r-lg) !important;
  overflow: hidden !important;
  display: flex !important;
  flex-direction: column !important;
  transition: transform var(--qs-dur-2) var(--qs-ease-out), box-shadow var(--qs-dur-2) var(--qs-ease-out), border-color var(--qs-dur-2) var(--qs-ease) !important;
  box-shadow: var(--qs-shadow-card) !important;
}

.product-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--qs-shadow-card-hover) !important;
  border-color: rgba(99, 102, 241, 0.2) !important;
}

.product-image-container {
  position: relative;
  background: var(--qs-bg-soft);
  aspect-ratio: 4 / 3;
  overflow: hidden;
}

.product-thumbnail {
  width: 100%;
  height: 100%;
  object-fit: cover;
  cursor: pointer;
  transition: transform var(--qs-dur-3) var(--qs-ease-out);
}

.product-card:hover .product-thumbnail {
  transform: scale(1.04);
}

.card-carousel-nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 32px; height: 32px;
  border-radius: var(--qs-r-full);
  background: rgba(255, 255, 255, 0.9);
  border: 1px solid var(--qs-line);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  opacity: 0;
  transition: opacity var(--qs-dur-2) var(--qs-ease), transform var(--qs-dur-2) var(--qs-ease);
  box-shadow: var(--qs-shadow-sm);
  color: var(--qs-ink-700);
  padding: 0;
}
.card-carousel-nav svg { width: 16px; height: 16px; }
.card-carousel-nav:hover { background: var(--qs-surface); transform: translateY(-50%) scale(1.05); }
.card-carousel-prev { left: 8px; }
.card-carousel-next { right: 8px; }
.product-card:hover .card-carousel-nav { opacity: 1; }

.card-carousel-dots {
  position: absolute;
  bottom: 8px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: 4px;
}
.carousel-dot {
  width: 6px; height: 6px;
  border-radius: var(--qs-r-full);
  background: rgba(255, 255, 255, 0.6);
  cursor: pointer;
  transition: background var(--qs-dur-1) var(--qs-ease), transform var(--qs-dur-1) var(--qs-ease);
  box-shadow: 0 0 0 1px rgba(15, 23, 42, 0.2);
}
.carousel-dot.active { background: #fff; transform: scale(1.4); }

.product-card-body {
  padding: 14px 16px 16px !important;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.product-card-body h3 {
  font-size: var(--qs-fz-base) !important;
  font-weight: 650 !important;
  letter-spacing: var(--qs-track-tight);
  color: var(--qs-ink-900) !important;
  margin: 0 !important;
  display: -webkit-box;
  -webkit-line-clamp: 1;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.product-code {
  font-size: var(--qs-fz-xs) !important;
  color: var(--qs-ink-400) !important;
  font-family: var(--qs-font-mono);
  margin: 0 !important;
}

.product-price {
  font-size: var(--qs-fz-lg) !important;
  font-weight: 700 !important;
  color: var(--qs-ink-900) !important;
  margin: 4px 0 !important;
  letter-spacing: var(--qs-track-tight);
}

.product-details {
  font-size: var(--qs-fz-xs) !important;
  color: var(--qs-ink-500) !important;
  margin: 0 !important;
}

.product-details .detail-label {
  font-weight: 600;
  color: var(--qs-ink-700);
}

.product-stock {
  display: inline-flex;
  align-items: center;
  align-self: flex-start;
  font-size: var(--qs-fz-xs) !important;
  font-weight: 600 !important;
  padding: 3px 10px !important;
  border-radius: var(--qs-r-full) !important;
  background: var(--qs-emerald-soft) !important;
  color: var(--qs-emerald) !important;
  margin-top: 4px !important;
  border: 1px solid rgba(16, 185, 129, 0.2);
}
.product-stock.low { background: var(--qs-amber-soft) !important; color: #b45309 !important; border-color: rgba(245, 158, 11, 0.24); }
.product-stock.out { background: var(--qs-rose-soft) !important; color: var(--qs-rose) !important; border-color: rgba(244, 63, 94, 0.22); }

.product-actions {
  display: flex !important;
  gap: 6px !important;
  margin-top: 12px !important;
  padding-top: 12px !important;
  border-top: 1px solid var(--qs-line-soft);
}

.product-actions .btn-small {
  flex: 1 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 4px !important;
  padding: 6px 8px !important;
  font-size: 12px !important;
}

.btn-danger-small {
  color: var(--qs-rose) !important;
  border-color: rgba(244, 63, 94, 0.24) !important;
}
.btn-danger-small:hover {
  background: var(--qs-rose-soft) !important;
  border-color: var(--qs-rose) !important;
  color: var(--qs-rose) !important;
}

/* ==========================================================================
   Order list (legacy .order-card / .order-item)
   ========================================================================== */
.order-card,
.order-item {
  background: var(--qs-surface) !important;
  border: 1px solid var(--qs-line) !important;
  border-radius: var(--qs-r-lg) !important;
  padding: 16px !important;
  transition: box-shadow var(--qs-dur-2) var(--qs-ease-out), border-color var(--qs-dur-2) var(--qs-ease) !important;
}
.order-card:hover {
  box-shadow: var(--qs-shadow-card-hover) !important;
  border-color: rgba(99, 102, 241, 0.18) !important;
}

.orders-list {
  display: flex !important;
  flex-direction: column !important;
  gap: 0;
  background: var(--qs-surface);
  border: 1px solid var(--qs-line);
  border-radius: var(--qs-r-lg);
  overflow: hidden;
  box-shadow: var(--qs-shadow-card);
}

.orders-list .order-item {
  border: none !important;
  border-bottom: 1px solid var(--qs-line-soft) !important;
  border-radius: 0 !important;
  background: transparent !important;
}
.orders-list .order-item:last-child { border-bottom: none !important; }
.orders-list .order-item:hover { background: var(--qs-bg-soft) !important; }

/* ==========================================================================
   Forms / fieldsets (legacy .form-row, .form-section)
   ========================================================================== */
.form-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 12px;
  margin-bottom: 12px;
}

.form-section {
  background: var(--qs-surface);
  border: 1px solid var(--qs-line);
  border-radius: var(--qs-r-lg);
  padding: 20px;
  margin-bottom: 16px;
  box-shadow: var(--qs-shadow-card);
}

.form-section h3,
.form-section h4 {
  font-size: var(--qs-fz-base) !important;
  font-weight: 650 !important;
  letter-spacing: var(--qs-track-tight);
  color: var(--qs-ink-900) !important;
  margin: 0 0 12px !important;
}

/* Switch / toggle */
input[type='checkbox'].qs-switch,
.qs-switch input[type='checkbox'] { display: none; }
.qs-switch {
  position: relative;
  display: inline-block;
  width: 36px;
  height: 20px;
}
.qs-switch-track {
  position: absolute;
  inset: 0;
  background: var(--qs-ink-200);
  border-radius: var(--qs-r-full);
  transition: background var(--qs-dur-2) var(--qs-ease);
  cursor: pointer;
}
.qs-switch-track::after {
  content: '';
  position: absolute;
  width: 16px; height: 16px;
  background: #fff;
  border-radius: var(--qs-r-full);
  top: 2px; left: 2px;
  box-shadow: var(--qs-shadow-sm);
  transition: transform var(--qs-dur-2) var(--qs-ease-spring);
}
.qs-switch input:checked + .qs-switch-track { background: var(--qs-brand); }
.qs-switch input:checked + .qs-switch-track::after { transform: translateX(16px); }

/* Activity list (admin) */
.activity-list .activity-item:hover { background: var(--qs-bg-soft); border-color: var(--qs-line-strong); }

/* ==========================================================================
   Orders page (toolbar, table, mobile cards, bulk action bar)
   ========================================================================== */
.orders-toolbar { gap: 8px !important; }

.orders-search {
  position: relative;
  flex: 1;
  min-width: 220px;
  max-width: 360px;
}

.orders-search-icon {
  position: absolute !important;
  left: 12px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--qs-ink-400) !important;
  pointer-events: none;
}

.orders-search input {
  padding-left: 38px !important;
  width: 100%;
  border-radius: var(--qs-r-full) !important;
  background: var(--qs-bg-soft) !important;
}

.orders-toolbar select,
.orders-toolbar input[type='date'] {
  border-radius: var(--qs-r-full) !important;
  padding: 7px 14px !important;
  background: var(--qs-bg-soft) !important;
  font-size: var(--qs-fz-sm) !important;
}

/* Bulk action bar */
.bulk-action-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: var(--qs-s-4);
  padding: 12px 16px;
  background: var(--qs-gradient-brand-soft);
  border: 1px solid rgba(99, 102, 241, 0.2);
  border-radius: var(--qs-r-lg);
  box-shadow: var(--qs-shadow-sm);
  position: sticky;
  top: var(--qs-topbar-h);
  z-index: 5;
  animation: qs-fade-in var(--qs-dur-2) var(--qs-ease-out);
}

.bulk-action-info {
  font-size: var(--qs-fz-sm);
  font-weight: 600;
  color: var(--qs-brand-700);
}
.bulk-action-info span { font-weight: 800; font-size: var(--qs-fz-base); }

.bulk-action-buttons { display: flex; gap: 8px; }

/* Table container */
.table-container {
  background: var(--qs-surface);
  border: 1px solid var(--qs-line);
  border-radius: var(--qs-r-lg);
  overflow: hidden;
  box-shadow: var(--qs-shadow-card);
}

.table-container table { border-radius: 0; }

.checkbox-col {
  width: 40px;
  text-align: center;
}
.checkbox-col input[type='checkbox'],
input.order-checkbox {
  width: 16px;
  height: 16px;
  accent-color: var(--qs-brand);
  cursor: pointer;
}

.checkbox-disabled { color: var(--qs-ink-300); }

/* DUP badge */
.dup-badge {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  margin-left: 6px;
  padding: 1px 7px;
  font-size: 10px;
  font-weight: 700;
  background: var(--qs-amber-soft);
  color: #b45309;
  border: 1px solid rgba(245, 158, 11, 0.32);
  border-radius: var(--qs-r-full);
  letter-spacing: 0.04em;
}

/* Mobile order cards */
.mobile-cards {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.mobile-card {
  background: var(--qs-surface);
  border: 1px solid var(--qs-line);
  border-radius: var(--qs-r-lg);
  box-shadow: var(--qs-shadow-card);
  overflow: hidden;
  transition: box-shadow var(--qs-dur-2) var(--qs-ease-out), border-color var(--qs-dur-2) var(--qs-ease);
}
.mobile-card:active { box-shadow: var(--qs-shadow-press); transform: scale(0.997); }

.mobile-card-header {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 14px;
  border-bottom: 1px solid var(--qs-line-soft);
  background: var(--qs-bg-soft);
}

.mobile-order-checkbox { flex-shrink: 0; }

.mobile-card-title {
  font-weight: 700;
  font-size: var(--qs-fz-sm);
  color: var(--qs-ink-900);
  letter-spacing: var(--qs-track-tight);
  flex: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
}

.mobile-card-body {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px 12px;
  padding: 12px 14px;
}

.mobile-card-row {
  display: flex;
  flex-direction: column;
  gap: 2px;
  font-size: var(--qs-fz-xs);
  min-width: 0;
}
.mobile-card-row:nth-child(3),
.mobile-card-row:nth-child(7) { grid-column: 1 / -1; }

.mobile-card-label {
  font-size: 10.5px;
  font-weight: 600;
  color: var(--qs-ink-400);
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.mobile-card-value {
  font-size: var(--qs-fz-sm);
  color: var(--qs-ink-900);
  font-weight: 500;
  overflow: hidden;
  text-overflow: ellipsis;
}

.mobile-card-actions {
  padding: 12px 14px;
  border-top: 1px solid var(--qs-line-soft);
  display: flex;
  gap: 8px;
}
.mobile-card-actions .btn-small { flex: 1; justify-content: center; }

/* Desktop / mobile show-hide helpers (matches OrdersPage usage) */
.desktop-only { display: block; }
.mobile-only { display: none; }
@media (max-width: 720px) {
  .desktop-only { display: none !important; }
  .mobile-only { display: block !important; }
  .bulk-action-bar { flex-wrap: wrap; padding: 10px; }
  .bulk-action-buttons { flex: 1; justify-content: flex-end; }
}

/* Modal footer + form-group */
.modal-footer {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  margin-top: 16px;
  padding-top: 16px;
  border-top: 1px solid var(--qs-line-soft);
}

.form-group { display: flex; flex-direction: column; gap: 6px; margin-bottom: 12px; }
.form-group label {
  font-size: var(--qs-fz-sm);
  font-weight: 600;
  color: var(--qs-ink-700);
}

.text-muted { color: var(--qs-ink-500); font-size: var(--qs-fz-sm); }

/* btn-icon helper */
.btn-icon { display: inline-flex; flex-shrink: 0; }

/* ==========================================================================
   Inbox page — conversation list, chat panel, message bubbles
   ========================================================================== */
.inbox-header {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 12px !important;
  padding: 14px 16px !important;
  background: var(--qs-surface) !important;
  border-bottom: 1px solid var(--qs-line-soft) !important;
}

.inbox-stats {
  display: flex !important;
  gap: 14px;
}

.inbox-stat {
  display: flex !important;
  flex-direction: column !important;
  align-items: center;
}

.inbox-stat .stat-value {
  font-size: var(--qs-fz-base) !important;
  font-weight: 700 !important;
  color: var(--qs-ink-900) !important;
  line-height: 1.1;
}

.inbox-stat .stat-label {
  font-size: 10.5px !important;
  text-transform: uppercase !important;
  letter-spacing: 0.06em !important;
  color: var(--qs-ink-400) !important;
  font-weight: 600 !important;
}

.inbox-filters {
  display: flex !important;
  flex-direction: column;
  gap: 8px;
  padding: 10px 14px !important;
  background: var(--qs-bg-soft) !important;
  border-bottom: 1px solid var(--qs-line-soft) !important;
}

.conversation-search {
  position: relative;
}
.conversation-search input {
  width: 100%;
  border-radius: var(--qs-r-full) !important;
  background: var(--qs-surface) !important;
  padding: 8px 14px !important;
}

/* Toggle switch (escalated filter) */
.filter-toggle {
  display: flex !important;
  align-items: center;
  gap: 10px;
  font-size: var(--qs-fz-sm);
  color: var(--qs-ink-700);
  cursor: pointer;
  user-select: none;
}
.filter-toggle input[type='checkbox'] { display: none; }
.filter-toggle .toggle-slider {
  position: relative;
  width: 36px; height: 20px;
  background: var(--qs-ink-200);
  border-radius: var(--qs-r-full);
  transition: background var(--qs-dur-2) var(--qs-ease);
  flex-shrink: 0;
}
.filter-toggle .toggle-slider::after {
  content: '';
  position: absolute;
  width: 16px; height: 16px;
  background: #fff;
  border-radius: var(--qs-r-full);
  top: 2px; left: 2px;
  box-shadow: var(--qs-shadow-sm);
  transition: transform var(--qs-dur-2) var(--qs-ease-spring);
}
.filter-toggle input:checked + .toggle-slider {
  background: var(--qs-brand);
}
.filter-toggle input:checked + .toggle-slider::after {
  transform: translateX(16px);
}
.escalated-count {
  margin-left: 4px;
  padding: 1px 8px;
  background: var(--qs-rose-soft);
  color: var(--qs-rose);
  border-radius: var(--qs-r-full);
  font-size: 11px;
  font-weight: 700;
}

/* Conversation list rows */
.conversation-list {
  background: var(--qs-surface);
}

.conversation-info {
  display: flex !important;
  gap: 12px !important;
  padding: 12px 14px !important;
  border-bottom: 1px solid var(--qs-line-soft) !important;
  cursor: pointer;
  transition: background var(--qs-dur-1) var(--qs-ease);
}
.conversation-info:hover { background: var(--qs-bg-soft); }
.conversation-info.active,
.conversation-info.selected {
  background: var(--qs-brand-50) !important;
  border-left: 3px solid var(--qs-brand);
  padding-left: 11px !important;
}

.conversation-header {
  display: flex !important;
  align-items: baseline !important;
  justify-content: space-between !important;
  gap: 8px;
  margin-bottom: 2px;
}

.conversation-name {
  font-size: var(--qs-fz-sm) !important;
  font-weight: 650 !important;
  color: var(--qs-ink-900) !important;
  letter-spacing: var(--qs-track-tight);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.conversation-time {
  font-size: 11.5px !important;
  color: var(--qs-ink-400) !important;
  flex-shrink: 0;
}

.conversation-preview {
  font-size: var(--qs-fz-sm) !important;
  color: var(--qs-ink-500) !important;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.unread-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 18px;
  height: 18px;
  padding: 0 6px;
  background: var(--qs-gradient-brand) !important;
  color: #fff !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  border-radius: var(--qs-r-full) !important;
  box-shadow: 0 4px 10px rgba(99, 102, 241, 0.35);
  margin-left: 4px;
}

.escalated-indicator {
  margin-left: 6px;
  color: var(--qs-rose);
}

.customer-id {
  font-size: 11px;
  color: var(--qs-ink-400);
  font-family: var(--qs-font-mono);
}

.channel-logo {
  width: 14px;
  height: 14px;
  flex-shrink: 0;
}

/* Chat panel */
.chat-panel {
  background: var(--qs-bg-soft) !important;
}

.chat-panel-empty {
  display: flex !important;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  height: 100%;
  color: var(--qs-ink-400);
  gap: 12px;
}
.chat-panel-empty .empty-icon {
  width: 64px; height: 64px;
  border-radius: var(--qs-r-full);
  background: var(--qs-surface);
  border: 1px solid var(--qs-line);
  display: flex; align-items: center; justify-content: center;
  color: var(--qs-brand);
  box-shadow: var(--qs-shadow-card);
}

.chat-header {
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  padding: 12px 16px !important;
  background: var(--qs-glass) !important;
  -webkit-backdrop-filter: blur(14px);
          backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--qs-line-soft) !important;
}

.chat-back-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px; height: 32px;
  border-radius: var(--qs-r);
  background: transparent;
  border: none;
  color: var(--qs-ink-700);
  cursor: pointer;
  transition: background var(--qs-dur-1) var(--qs-ease);
}
.chat-back-btn:hover { background: var(--qs-ink-50); color: var(--qs-ink-900); }

.chat-customer-info { flex: 1; min-width: 0; }

.chat-actions { display: flex; gap: 6px; align-items: center; }

.chat-messages {
  background: var(--qs-bg-soft) !important;
  padding: 16px !important;
  background-image:
    radial-gradient(circle at 8% 20%, rgba(99, 102, 241, 0.04), transparent 30%),
    radial-gradient(circle at 90% 80%, rgba(217, 70, 239, 0.04), transparent 30%);
}

.date-separator {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 12px 0;
  font-size: 11px;
  color: var(--qs-ink-400);
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  position: relative;
}
.date-separator::before, .date-separator::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--qs-line-soft);
  margin: 0 12px;
}

/* Message bubbles */
.message-bubble {
  max-width: 70%;
  padding: 9px 14px !important;
  border-radius: var(--qs-r-lg) !important;
  font-size: var(--qs-fz-sm) !important;
  line-height: 1.45 !important;
  box-shadow: var(--qs-shadow-xs) !important;
  word-break: break-word;
  position: relative;
  letter-spacing: -0.005em;
}

.message-bubble.inbound {
  background: var(--qs-surface) !important;
  color: var(--qs-ink-900) !important;
  border: 1px solid var(--qs-line-soft) !important;
  border-bottom-left-radius: 6px !important;
}

.message-bubble.outbound,
.message-bubble.sent {
  background: var(--qs-gradient-brand) !important;
  color: #fff !important;
  border: none !important;
  border-bottom-right-radius: 6px !important;
  box-shadow: 0 6px 14px rgba(99, 102, 241, 0.25) !important;
}

.message-bubble.outbound a,
.message-bubble.sent a { color: #fff; text-decoration: underline; }

.message-meta {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 10.5px;
  margin-top: 4px;
  opacity: 0.75;
}
.message-bubble.outbound .message-meta { color: rgba(255, 255, 255, 0.85); }
.message-bubble.inbound .message-meta { color: var(--qs-ink-400); }

.msg-status.sending { opacity: 0.6; }
.msg-status.sent { opacity: 0.95; }

.message-image {
  max-width: 100%;
  border-radius: var(--qs-r);
  display: block;
}
.message-image-caption {
  margin-top: 6px;
  font-size: var(--qs-fz-sm);
}

/* Chat input */
.chat-input {
  display: flex !important;
  align-items: flex-end;
  gap: 8px !important;
  padding: 10px 12px !important;
  background: var(--qs-surface) !important;
  border-top: 1px solid var(--qs-line-soft) !important;
}

.chat-input textarea {
  flex: 1;
  min-height: 38px;
  max-height: 140px;
  border-radius: var(--qs-r-lg) !important;
  background: var(--qs-bg-soft) !important;
  resize: none;
}

.attach-btn,
.send-btn {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 38px;
  height: 38px;
  border-radius: var(--qs-r-full) !important;
  border: none !important;
  cursor: pointer;
  flex-shrink: 0;
  padding: 0 !important;
}

.attach-btn {
  background: var(--qs-bg-soft) !important;
  color: var(--qs-ink-600) !important;
  border: 1px solid var(--qs-line) !important;
}
.attach-btn:hover { background: var(--qs-ink-50) !important; }

.send-btn {
  background: var(--qs-gradient-brand) !important;
  color: #fff !important;
  box-shadow: 0 6px 14px rgba(99, 102, 241, 0.32);
  transition: transform var(--qs-dur-1) var(--qs-ease);
}
.send-btn:hover:not(:disabled) { transform: scale(1.06); }
.send-btn:disabled { opacity: 0.5; cursor: not-allowed; }

.message-tag-row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  background: var(--qs-amber-soft);
  border-bottom: 1px solid rgba(245, 158, 11, 0.2);
  font-size: var(--qs-fz-xs);
  color: #b45309;
}

.message-tag-select { font-size: 12px !important; padding: 4px 24px 4px 10px !important; }
.tag-hint { color: var(--qs-ink-400); font-size: 11px; }

.ai-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 2px 8px;
  background: linear-gradient(135deg, var(--qs-violet), var(--qs-fuchsia));
  color: #fff;
  font-size: 10.5px;
  font-weight: 700;
  border-radius: var(--qs-r-full);
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.ai-toggle { display: flex; align-items: center; gap: 6px; }

/* ==========================================================================
   Inventory page (tiles + table)
   ========================================================================== */
.inventory-tiles {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
  margin-bottom: var(--qs-s-5);
}

@media (max-width: 1024px) { .inventory-tiles { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px) { .inventory-tiles { grid-template-columns: 1fr 1fr; gap: 10px; } }

.inventory-tile {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 18px;
  background: var(--qs-surface);
  border: 1px solid var(--qs-line);
  border-radius: var(--qs-r-lg);
  box-shadow: var(--qs-shadow-card);
  cursor: default;
  text-align: left;
  font-family: inherit;
  position: relative;
  overflow: hidden;
  transition: transform var(--qs-dur-2) var(--qs-ease-out), box-shadow var(--qs-dur-2) var(--qs-ease-out), border-color var(--qs-dur-2) var(--qs-ease);
}

.inventory-tile.clickable { cursor: pointer; }
.inventory-tile.clickable:hover { transform: translateY(-2px); box-shadow: var(--qs-shadow-card-hover); }
.inventory-tile.active {
  border-color: var(--qs-brand) !important;
  box-shadow: 0 0 0 1px var(--qs-brand-ring), var(--qs-shadow-card);
}

.inventory-tile::before {
  content: '';
  position: absolute;
  top: 0; left: 0;
  width: 100%; height: 3px;
  opacity: 0.85;
}
.inventory-tile.tile-neutral::before { background: var(--qs-gradient-brand); }
.inventory-tile.tile-good::before    { background: var(--qs-gradient-emerald); }
.inventory-tile.tile-warn::before    { background: var(--qs-gradient-amber); }
.inventory-tile.tile-bad::before     { background: var(--qs-gradient-rose); }

.inventory-tile-icon {
  width: 42px; height: 42px;
  border-radius: var(--qs-r);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  background: var(--qs-brand-soft);
  color: var(--qs-brand-700);
}
.tile-neutral .inventory-tile-icon { background: var(--qs-brand-soft); color: var(--qs-brand-700); }
.tile-good .inventory-tile-icon { background: var(--qs-emerald-soft); color: var(--qs-emerald); }
.tile-warn .inventory-tile-icon { background: var(--qs-amber-soft); color: #b45309; }
.tile-bad  .inventory-tile-icon { background: var(--qs-rose-soft); color: var(--qs-rose); }

.inventory-tile-value {
  font-size: var(--qs-fz-2xl);
  font-weight: 800;
  letter-spacing: var(--qs-track-tighter);
  color: var(--qs-ink-900);
  line-height: 1.05;
}

.inventory-tile-label {
  font-size: var(--qs-fz-xs);
  color: var(--qs-ink-500);
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.inventory-table-wrap {
  background: var(--qs-surface);
  border: 1px solid var(--qs-line);
  border-radius: var(--qs-r-lg);
  overflow: hidden;
  box-shadow: var(--qs-shadow-card);
}
.inventory-table { background: transparent; border-radius: 0; }
.inventory-table tbody tr.row-low { background: rgba(245, 158, 11, 0.04); }
.inventory-table tbody tr.row-out { background: rgba(244, 63, 94, 0.05); }
.inventory-table tbody tr:hover { background: var(--qs-bg-soft); }
.inventory-table tbody tr.row-low:hover { background: rgba(245, 158, 11, 0.08); }
.inventory-table tbody tr.row-out:hover { background: rgba(244, 63, 94, 0.08); }

.inventory-product-name {
  font-weight: 600;
  color: var(--qs-ink-900);
  letter-spacing: var(--qs-track-tight);
}
.inventory-product-code {
  font-size: 11.5px;
  color: var(--qs-ink-400);
  font-family: var(--qs-font-mono);
  margin-top: 2px;
}

/* Adjust stock modal */
.adjust-stock-form { display: flex; flex-direction: column; gap: 14px; }

.adjust-stock-summary {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  padding: 14px;
  background: var(--qs-bg-soft);
  border: 1px solid var(--qs-line);
  border-radius: var(--qs-r-md);
}
.adjust-stock-current {
  font-size: var(--qs-fz-xl);
  font-weight: 800;
  color: var(--qs-ink-900);
  letter-spacing: var(--qs-track-tighter);
}

.form-label {
  font-size: var(--qs-fz-sm);
  font-weight: 600;
  color: var(--qs-ink-700);
}

.adjust-stock-delta {
  display: flex;
  align-items: center;
  gap: 8px;
}
.adjust-stock-delta input {
  flex: 1;
  text-align: center;
  font-weight: 700;
  font-size: var(--qs-fz-base);
}
.adjust-stock-delta .btn-small {
  width: 38px;
  height: 38px;
  padding: 0 !important;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.modal-actions {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  margin-top: 8px;
  padding-top: 14px;
  border-top: 1px solid var(--qs-line-soft);
}

/* ==========================================================================
   Courier ops — tabs
   ========================================================================== */
.courier-ops-tabs {
  display: flex;
  gap: 4px;
  flex-wrap: wrap;
  width: 100%;
  background: var(--qs-bg-soft);
  padding: 4px;
  border-radius: var(--qs-r-md);
  border: 1px solid var(--qs-line-soft);
}

.courier-ops-tab {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 7px 14px;
  background: transparent;
  border: none;
  border-radius: var(--qs-r);
  color: var(--qs-ink-500);
  font-weight: 600;
  font-size: var(--qs-fz-sm);
  font-family: inherit;
  cursor: pointer;
  transition: background var(--qs-dur-1) var(--qs-ease), color var(--qs-dur-1) var(--qs-ease);
}
.courier-ops-tab:hover { color: var(--qs-ink-800); }
.courier-ops-tab.active {
  background: var(--qs-surface);
  color: var(--qs-ink-900);
  box-shadow: var(--qs-shadow-xs), 0 0 0 1px var(--qs-line);
}

.tab-count {
  min-width: 20px;
  padding: 1px 7px;
  background: var(--qs-ink-100);
  color: var(--qs-ink-700);
  border-radius: var(--qs-r-full);
  font-size: 11px;
  font-weight: 700;
  text-align: center;
}
.courier-ops-tab.active .tab-count {
  background: var(--qs-brand-soft);
  color: var(--qs-brand-700);
}

.tab-unresolved {
  padding: 1px 7px;
  background: var(--qs-rose-soft);
  color: var(--qs-rose);
  border-radius: var(--qs-r-full);
  font-size: 10.5px;
  font-weight: 700;
  border: 1px solid rgba(244, 63, 94, 0.22);
}

/* ==========================================================================
   Reports page — toolbar, tiles, charts, tables
   ========================================================================== */
.reports-toolbar {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: var(--qs-s-5);
  padding: 12px 16px;
  background: var(--qs-surface);
  border: 1px solid var(--qs-line);
  border-radius: var(--qs-r-lg);
  box-shadow: var(--qs-shadow-card);
  flex-wrap: wrap;
}

.reports-presets {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

.btn-chip {
  appearance: none;
  background: var(--qs-bg-soft) !important;
  color: var(--qs-ink-700) !important;
  border: 1px solid var(--qs-line) !important;
  border-radius: var(--qs-r-full) !important;
  padding: 6px 14px !important;
  font-size: var(--qs-fz-xs) !important;
  font-weight: 600 !important;
  cursor: pointer;
  font-family: inherit;
  transition: background var(--qs-dur-1) var(--qs-ease), color var(--qs-dur-1) var(--qs-ease), border-color var(--qs-dur-1) var(--qs-ease);
}
.btn-chip:hover {
  background: var(--qs-brand-soft) !important;
  color: var(--qs-brand-700) !important;
  border-color: rgba(99, 102, 241, 0.32) !important;
}
.btn-chip.active {
  background: var(--qs-gradient-brand) !important;
  color: #fff !important;
  border-color: transparent !important;
}

.reports-range {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-left: auto;
  flex-wrap: wrap;
}
.reports-range label {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: var(--qs-fz-xs);
  font-weight: 600;
  color: var(--qs-ink-500);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.reports-range input[type='date'] {
  padding: 6px 10px !important;
  font-size: var(--qs-fz-sm) !important;
}

/* KPI tiles */
.reports-tiles {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
  margin-bottom: var(--qs-s-5);
}
@media (max-width: 1024px) { .reports-tiles { grid-template-columns: repeat(2, 1fr); } }

.reports-tile,
.kpi-tile {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 18px;
  background: var(--qs-surface);
  border: 1px solid var(--qs-line);
  border-radius: var(--qs-r-lg);
  box-shadow: var(--qs-shadow-card);
  position: relative;
  overflow: hidden;
  transition: transform var(--qs-dur-2) var(--qs-ease-out), box-shadow var(--qs-dur-2) var(--qs-ease-out);
}
.reports-tile:hover,
.kpi-tile:hover { transform: translateY(-2px); box-shadow: var(--qs-shadow-card-hover); }

.reports-tile::before,
.kpi-tile::before {
  content: '';
  position: absolute;
  top: 0; left: 0;
  width: 100%; height: 3px;
  background: var(--qs-gradient-brand);
  opacity: 0.85;
}
.reports-tile.tile-good::before, .kpi-tile.tile-good::before { background: var(--qs-gradient-emerald); }
.reports-tile.tile-warn::before, .kpi-tile.tile-warn::before { background: var(--qs-gradient-amber); }
.reports-tile.tile-bad::before,  .kpi-tile.tile-bad::before  { background: var(--qs-gradient-rose); }
.reports-tile.tile-neutral::before, .kpi-tile.tile-neutral::before { background: var(--qs-gradient-brand); }

.reports-tile-icon,
.kpi-tile-icon {
  width: 42px; height: 42px;
  border-radius: var(--qs-r);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  background: var(--qs-brand-soft);
  color: var(--qs-brand-700);
}
.tile-good .reports-tile-icon, .tile-good .kpi-tile-icon { background: var(--qs-emerald-soft); color: var(--qs-emerald); }
.tile-warn .reports-tile-icon, .tile-warn .kpi-tile-icon { background: var(--qs-amber-soft); color: #b45309; }
.tile-bad  .reports-tile-icon, .tile-bad  .kpi-tile-icon { background: var(--qs-rose-soft); color: var(--qs-rose); }

.reports-tile-value,
.kpi-tile-value {
  font-size: var(--qs-fz-xl);
  font-weight: 800;
  letter-spacing: var(--qs-track-tighter);
  color: var(--qs-ink-900);
  line-height: 1.1;
}

.reports-tile-label,
.kpi-tile-label {
  font-size: var(--qs-fz-xs);
  font-weight: 600;
  color: var(--qs-ink-500);
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.reports-tile-hint,
.kpi-tile-hint {
  font-size: var(--qs-fz-xs);
  color: var(--qs-ink-400);
  margin-top: 4px;
}

/* Reports grid (chart + tables) */
.reports-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
@media (max-width: 1024px) { .reports-grid { grid-template-columns: 1fr; } }

.reports-card {
  background: var(--qs-surface);
  border: 1px solid var(--qs-line);
  border-radius: var(--qs-r-lg);
  box-shadow: var(--qs-shadow-card);
  overflow: hidden;
}

.reports-card-header {
  padding: 14px 18px;
  border-bottom: 1px solid var(--qs-line-soft);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.reports-card-header h3 {
  font-size: var(--qs-fz-base);
  font-weight: 650;
  color: var(--qs-ink-900);
  margin: 0;
  letter-spacing: var(--qs-track-tight);
}

.reports-chart-wrap { padding: 14px 18px; }

.reports-chart-meta {
  font-size: var(--qs-fz-xs);
  color: var(--qs-ink-400);
  margin-bottom: 8px;
}

.reports-chart {
  width: 100%;
  height: 220px;
}

.reports-chart-legend {
  display: flex;
  gap: 12px;
  margin-top: 8px;
  flex-wrap: wrap;
}
.legend-item {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: var(--qs-fz-xs);
  color: var(--qs-ink-500);
  font-weight: 500;
}
.legend-swatch {
  display: inline-block;
  width: 14px; height: 4px;
  border-radius: 2px;
  background: var(--qs-brand);
}
.legend-swatch.legend-dashed {
  background: repeating-linear-gradient(90deg, var(--qs-emerald) 0 4px, transparent 4px 7px);
}

.reports-table {
  width: 100%;
  border-radius: 0;
}

/* ==========================================================================
   Developers page
   ========================================================================== */
.view-header-info {
  display: flex;
  flex-direction: column;
  gap: 4px;
  flex: 1;
}
.view-header-info h2 {
  font-size: var(--qs-fz-lg) !important;
  font-weight: 650 !important;
  letter-spacing: var(--qs-track-tight);
  margin: 0 !important;
}
.view-header-info p { font-size: var(--qs-fz-sm); color: var(--qs-ink-500); margin: 0; }

.api-key-display {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 12px 14px;
  background: var(--qs-ink-900);
  color: #f3f4f6;
  border-radius: var(--qs-r-md);
  font-family: var(--qs-font-mono);
  font-size: var(--qs-fz-xs);
  border: 1px solid var(--qs-ink-800);
}

.copy-btn {
  margin-left: auto;
  padding: 5px 10px;
  background: rgba(255, 255, 255, 0.08);
  color: #fff;
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: var(--qs-r);
  font-size: var(--qs-fz-xs);
  font-weight: 600;
  cursor: pointer;
  transition: background var(--qs-dur-1) var(--qs-ease);
}
.copy-btn:hover { background: rgba(255, 255, 255, 0.18); }

.channel-section {
  background: var(--qs-surface);
  border: 1px solid var(--qs-line);
  border-radius: var(--qs-r-lg);
  padding: 20px;
  margin-bottom: 16px;
  box-shadow: var(--qs-shadow-card);
}

.channel-section-title {
  font-size: var(--qs-fz-base);
  font-weight: 650;
  color: var(--qs-ink-900);
  margin: 0 0 12px;
  letter-spacing: var(--qs-track-tight);
}

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

.channel-card {
  background: var(--qs-surface);
  border: 1px solid var(--qs-line);
  border-radius: var(--qs-r-md);
  padding: 14px;
  transition: box-shadow var(--qs-dur-2) var(--qs-ease-out), border-color var(--qs-dur-2) var(--qs-ease);
}
.channel-card:hover { border-color: rgba(99, 102, 241, 0.18); box-shadow: var(--qs-shadow-card-hover); }

.channel-card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 8px;
}
.channel-name { font-size: var(--qs-fz-sm); font-weight: 650; color: var(--qs-ink-900); }

.channel-actions { display: flex; gap: 6px; }

.webhook-url {
  display: block;
  width: 100%;
  padding: 8px 10px;
  background: var(--qs-bg-soft);
  border: 1px solid var(--qs-line);
  border-radius: var(--qs-r-sm);
  font-family: var(--qs-font-mono);
  font-size: 11.5px;
  color: var(--qs-ink-700);
  word-break: break-all;
}

.webhook-tip {
  font-size: var(--qs-fz-xs);
  color: var(--qs-ink-400);
  background: var(--qs-info-soft);
  border-radius: var(--qs-r-sm);
  padding: 8px 10px;
  border: 1px solid rgba(14, 165, 233, 0.16);
  margin-top: 6px;
}

/* Code blocks */
.code-box {
  background: var(--qs-ink-900);
  color: #f3f4f6;
  border-radius: var(--qs-r-md);
  overflow: hidden;
  border: 1px solid var(--qs-ink-800);
}
.code-box-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 8px 12px;
  background: var(--qs-ink-800);
  color: var(--qs-ink-300);
  font-size: var(--qs-fz-xs);
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.code-box pre {
  padding: 12px;
  margin: 0;
  font-family: var(--qs-font-mono);
  font-size: 12.5px;
  line-height: 1.55;
  overflow-x: auto;
}

.code-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
@media (max-width: 900px) { .code-grid { grid-template-columns: 1fr; } }

/* Method pills */
.method {
  display: inline-block;
  padding: 2px 8px;
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 0.04em;
  border-radius: var(--qs-r-sm);
  text-transform: uppercase;
}
.method.get  { background: var(--qs-info-soft); color: #0369a1; }
.method.post { background: var(--qs-emerald-soft); color: var(--qs-emerald); }
.method.put  { background: var(--qs-amber-soft); color: #b45309; }
.method.del,
.method.delete { background: var(--qs-rose-soft); color: var(--qs-rose); }

/* Form actions */
.form-actions {
  display: flex;
  gap: 8px;
  justify-content: flex-end;
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid var(--qs-line-soft);
}

.form-group.half { width: 100%; }

/* Field hint */
.field-hint {
  font-size: var(--qs-fz-xs);
  color: var(--qs-ink-400);
  margin-top: 4px;
}

.btn-danger {
  background: var(--qs-rose) !important;
  color: #fff !important;
  border: none !important;
}
.btn-danger:hover { background: #e11d48 !important; }

/* ==========================================================================
   Settings page
   ========================================================================== */
.settings-section {
  background: var(--qs-surface);
  border: 1px solid var(--qs-line);
  border-radius: var(--qs-r-lg);
  padding: 22px;
  margin-bottom: 16px;
  box-shadow: var(--qs-shadow-card);
}

.settings-section > h2,
.settings-section > h3 {
  font-size: var(--qs-fz-lg);
  font-weight: 650;
  color: var(--qs-ink-900);
  letter-spacing: var(--qs-track-tight);
  margin: 0 0 6px;
}

.section-description,
.subsection-description {
  font-size: var(--qs-fz-sm);
  color: var(--qs-ink-500);
  margin: 0 0 16px;
  max-width: 640px;
}

.fields-subsection { margin-bottom: 18px; }
.fields-subsection > h4 {
  font-size: var(--qs-fz-sm);
  font-weight: 700;
  color: var(--qs-ink-700);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  margin: 0 0 8px;
}

/* Field cards */
.field-card,
.product-field-item,
.order-field-item,
.field-item {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 12px 14px;
  background: var(--qs-bg-soft);
  border: 1px solid var(--qs-line);
  border-radius: var(--qs-r-md);
  margin-bottom: 8px;
  transition: border-color var(--qs-dur-1) var(--qs-ease), background var(--qs-dur-1) var(--qs-ease);
}
.field-card:hover, .product-field-item:hover { border-color: var(--qs-line-strong); }
.field-item.disabled { opacity: 0.55; }

.field-info { flex: 1; min-width: 0; }
.field-label-bn { font-size: var(--qs-fz-sm); font-weight: 600; color: var(--qs-ink-900); }
.field-key {
  font-family: var(--qs-font-mono);
  font-size: 11.5px;
  color: var(--qs-ink-400);
  margin-top: 2px;
}
.field-type {
  display: inline-block;
  padding: 1px 8px;
  background: var(--qs-brand-soft);
  color: var(--qs-brand-700);
  border-radius: var(--qs-r-full);
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  margin-top: 4px;
}
.field-actions { display: flex; gap: 6px; flex-shrink: 0; }
.field-toggles { display: flex; gap: 12px; margin-top: 8px; }

.field-value-copy {
  display: flex;
  align-items: center;
  gap: 6px;
  font-family: var(--qs-font-mono);
  font-size: 11.5px;
  background: var(--qs-surface);
  border: 1px solid var(--qs-line);
  padding: 6px 10px;
  border-radius: var(--qs-r-sm);
  color: var(--qs-ink-700);
}

.help-text,
.field-hint {
  font-size: var(--qs-fz-xs);
  color: var(--qs-ink-400);
  margin-top: 4px;
}

/* Channel info card */
.channel-info-card {
  background: linear-gradient(180deg, var(--qs-surface), var(--qs-bg-soft));
  border: 1px solid var(--qs-line);
  border-radius: var(--qs-r-lg);
  padding: 20px;
  margin-bottom: 16px;
  box-shadow: var(--qs-shadow-card);
}

.channel-info-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 14px;
}

.channel-info-title {
  font-size: var(--qs-fz-lg);
  font-weight: 650;
  color: var(--qs-ink-900);
  margin: 0;
}

.channel-info-id {
  font-family: var(--qs-font-mono);
  font-size: var(--qs-fz-xs);
  color: var(--qs-ink-400);
  margin-top: 2px;
}

.channel-info-actions { display: flex; gap: 6px; }

.channel-info-fields {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 10px;
}

.channel-field {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: 10px;
  background: var(--qs-surface);
  border: 1px solid var(--qs-line);
  border-radius: var(--qs-r-sm);
}

.copy-field {
  display: flex;
  align-items: center;
  gap: 6px;
  background: var(--qs-bg-soft);
  border: 1px solid var(--qs-line);
  border-radius: var(--qs-r);
  padding: 6px 8px;
  font-family: var(--qs-font-mono);
  font-size: 11.5px;
  color: var(--qs-ink-700);
}
.btn-copy,
.copy-field button {
  padding: 4px 10px;
  background: transparent;
  color: var(--qs-brand-700);
  border: none;
  font-size: 11.5px;
  font-weight: 600;
  cursor: pointer;
  border-radius: var(--qs-r-sm);
  transition: background var(--qs-dur-1) var(--qs-ease);
}
.btn-copy:hover,
.copy-field button:hover { background: var(--qs-brand-soft); }

/* Toggle group */
.toggle-group {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.toggle-label {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: var(--qs-fz-sm);
  color: var(--qs-ink-700);
  cursor: pointer;
}

/* Catalog status / posts list */
.catalog-status {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  background: var(--qs-emerald-soft);
  color: var(--qs-emerald);
  border-radius: var(--qs-r-full);
  font-size: var(--qs-fz-xs);
  font-weight: 600;
  border: 1px solid rgba(16, 185, 129, 0.2);
}

/* Stores section */
.stores-controls {
  display: flex;
  gap: 10px;
  margin-bottom: 12px;
  flex-wrap: wrap;
}
.stores-search { flex: 1; min-width: 220px; }
.stores-filter select { padding: 8px 14px !important; }

.stores-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.store-info {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 12px 14px;
  background: var(--qs-surface);
  border: 1px solid var(--qs-line);
  border-radius: var(--qs-r-md);
  font-size: var(--qs-fz-sm);
}

.store-actions { display: flex; gap: 6px; }

.stores-pagination {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 10px;
  font-size: var(--qs-fz-xs);
  color: var(--qs-ink-500);
}

.template-variables {
  background: var(--qs-bg-soft);
  border: 1px solid var(--qs-line);
  border-radius: var(--qs-r-sm);
  padding: 8px 10px;
  font-family: var(--qs-font-mono);
  font-size: 11.5px;
  color: var(--qs-ink-700);
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.button-group { display: flex; gap: 8px; flex-wrap: wrap; }
.posts-list { display: flex; flex-direction: column; gap: 6px; }
.delivery-charges {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

/* Badges */
.badge.success { background: var(--qs-emerald-soft); color: var(--qs-emerald); border-color: rgba(16, 185, 129, 0.2); }
.badge.required { background: var(--qs-rose-soft); color: var(--qs-rose); border-color: rgba(244, 63, 94, 0.22); }
.badge.chat { background: var(--qs-info-soft); color: #0369a1; border-color: rgba(14, 165, 233, 0.22); }

/* ==========================================================================
   Admin pages — plans, users, search bar, data tables
   ========================================================================== */
.plans-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 16px;
}

.plan-card {
  background: var(--qs-surface);
  border: 1px solid var(--qs-line);
  border-radius: var(--qs-r-lg);
  box-shadow: var(--qs-shadow-card);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  transition: transform var(--qs-dur-2) var(--qs-ease-out), box-shadow var(--qs-dur-2) var(--qs-ease-out), border-color var(--qs-dur-2) var(--qs-ease);
  position: relative;
}

.plan-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0;
  width: 100%; height: 4px;
  background: linear-gradient(135deg, #7c3aed 0%, #a855f7 50%, #d946ef 100%);
}

.plan-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--qs-shadow-card-hover);
  border-color: rgba(124, 58, 237, 0.2);
}

.plan-card-header {
  padding: 18px 18px 12px;
  border-bottom: 1px solid var(--qs-line-soft);
}
.plan-card-title { display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.plan-name {
  font-size: var(--qs-fz-lg);
  font-weight: 700;
  color: var(--qs-ink-900);
  letter-spacing: var(--qs-track-tight);
}
.plan-price {
  font-size: var(--qs-fz-2xl);
  font-weight: 800;
  color: var(--qs-ink-900);
  background: linear-gradient(135deg, #7c3aed 0%, #d946ef 100%);
  -webkit-background-clip: text;
          background-clip: text;
  -webkit-text-fill-color: transparent;
  letter-spacing: var(--qs-track-tighter);
  margin-top: 6px;
}

.plan-card-body { padding: 16px 18px; flex: 1; }

.plan-features {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.plan-feature {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: var(--qs-fz-sm);
  color: var(--qs-ink-700);
}
.plan-feature::before {
  content: '✓';
  color: var(--qs-emerald);
  font-weight: 700;
  flex-shrink: 0;
}

.plan-limits {
  display: flex;
  flex-direction: column;
  gap: 4px;
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid var(--qs-line-soft);
}
.plan-limit { font-size: var(--qs-fz-xs); color: var(--qs-ink-500); }

.plan-card-footer {
  display: flex;
  gap: 6px;
  padding: 14px 18px;
  background: var(--qs-bg-soft);
  border-top: 1px solid var(--qs-line-soft);
}
.plan-card-footer button { flex: 1; }

/* Search bar primitive */
.search-bar { margin-bottom: var(--qs-s-4); }

.search-input-wrapper {
  position: relative;
  max-width: 480px;
}
.search-input-wrapper .search-icon {
  position: absolute;
  left: 12px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--qs-ink-400);
  pointer-events: none;
}
.search-input-wrapper input {
  padding-left: 38px !important;
  width: 100%;
  border-radius: var(--qs-r-full) !important;
  background: var(--qs-bg-soft) !important;
}

/* Data table (admin) */
.data-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  background: var(--qs-surface);
  border-radius: var(--qs-r-lg);
  overflow: hidden;
}
.data-table thead th { background: var(--qs-bg-soft); font-size: 11px; }

/* Action buttons in tables */
.action-buttons {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

/* Active state row */
tr.active td {
  background: var(--qs-emerald-soft);
}
