/* HiveX New UI - Design System from systemv-recolor-refresh */
/* All styles centralized here - no inline CSS, no hardcoded colors */
/* This file is auto-generated from CSS modules. Edit modules/*.css files instead. */
/* Generated by build_css.py - DO NOT EDIT THIS FILE DIRECTLY */


/* ============================================
   Module: variables.css
   ============================================ */

/* HiveX New UI - Design System from systemv-recolor-refresh */
/* All styles centralized here - no inline CSS, no hardcoded colors */

/* ============================================
   CSS Variables - Design Tokens
   ============================================ */

:root {
  /* Base Colors - HSL format only */
  --background: 240 4% 4%;
  --foreground: 0 0% 100%;

  --card: 240 2% 11%;
  --card-foreground: 0 0% 100%;

  --popover: 240 2% 11%;
  --popover-foreground: 0 0% 100%;

  --primary: 45 63% 49%;
  --primary-foreground: 0 0% 0%;

  --secondary: 240 2% 11%;
  --secondary-foreground: 0 0% 100%;

  --muted: 240 2% 16%;
  --muted-foreground: 0 0% 64%;

  --accent: 45 63% 49%;
  --accent-foreground: 0 0% 0%;

  --destructive: 0 62.8% 30.6%;
  --destructive-foreground: 0 0% 100%;

  --border: 240 2% 16%;
  --input: 240 2% 16%;
  --ring: 45 63% 49%;

  --radius: 0.75rem;

  /* Sidebar Colors */
  --sidebar-background: 240 4% 7%;
  --sidebar-foreground: 0 0% 100%;
  --sidebar-primary: 45 63% 49%;
  --sidebar-primary-foreground: 0 0% 0%;
  --sidebar-accent: 240 2% 11%;
  --sidebar-accent-foreground: 0 0% 100%;
  --sidebar-border: 240 2% 16%;
  --sidebar-ring: 45 63% 49%;

  /* Dashboard specific colors */
  --dashboard-bg: 240 4% 4%;
  --dashboard-card: 240 2% 11%;
  --dashboard-card-hover: 240 2% 14%;
  --dashboard-border: 240 2% 16%;
  --dashboard-accent: 45 63% 49%;
  --dashboard-text: 0 0% 100%;
  --dashboard-text-muted: 0 0% 64%;

  /* Accessibility / Feedback widgets */
  --a11y-fab-bg: 0 0% 0%;
  --a11y-fab-fg: 0 0% 100%;
  --a11y-overlay: 0 0% 0%;
  --a11y-shadow: 0 0% 0%;
}

/* Dark mode (default) - same as root for now */
.dark {
  --background: 240 4% 4%;
  --foreground: 0 0% 100%;

  --card: 240 2% 11%;
  --card-foreground: 0 0% 100%;

  --popover: 240 2% 11%;
  --popover-foreground: 0 0% 100%;

  --primary: 45 63% 49%;
  --primary-foreground: 0 0% 0%;

  --secondary: 240 2% 11%;
  --secondary-foreground: 0 0% 100%;

  --muted: 240 2% 16%;
  --muted-foreground: 0 0% 64%;

  --accent: 45 63% 49%;
  --accent-foreground: 0 0% 0%;

  --destructive: 0 62.8% 30.6%;
  --destructive-foreground: 0 0% 100%;

  --border: 240 2% 16%;
  --input: 240 2% 16%;
  --ring: 45 63% 49%;
  
  --sidebar-background: 240 4% 7%;
  --sidebar-foreground: 0 0% 100%;
  --sidebar-primary: 45 63% 49%;
  --sidebar-primary-foreground: 0 0% 0%;
  --sidebar-accent: 240 2% 11%;
  --sidebar-accent-foreground: 0 0% 100%;
  --sidebar-border: 240 2% 16%;
  --sidebar-ring: 45 63% 49%;

  --dashboard-bg: 240 4% 4%;
  --dashboard-card: 240 2% 11%;
  --dashboard-card-hover: 240 2% 14%;
  --dashboard-border: 240 2% 16%;
  --dashboard-accent: 45 63% 49%;
  --dashboard-text: 0 0% 100%;
  --dashboard-text-muted: 0 0% 64%;

  /* Platform brand colors */
  --platform-meta: 217 89% 51%;
  --platform-google: 45 93% 47%;
  --platform-tiktok: 0 0% 100%;
  --platform-pinterest: 0 100% 45%;
  --platform-x: 0 0% 42%;

  /* Workspace colors palette */
  --workspace-color-1: 45 63% 49%;
  --workspace-color-2: 217 89% 51%;
  --workspace-color-3: 142 71% 45%;
  --workspace-color-4: 45 93% 47%;
  --workspace-color-5: 0 84% 60%;
  --workspace-color-6: 262 83% 58%;
  --workspace-color-7: 330 81% 60%;
  --workspace-color-8: 188 94% 43%;

  /* Status colors - matching systemv green-500, yellow-500, red-500 */
  --status-active: 142 71% 45%;
  --status-paused: 45 93% 47%;
  --status-disconnected: 0 84% 60%;

  /* Red color variants for destructive actions */
  --color-red: 0 84% 60%;
  --color-red-light: 0 72% 58%;
}



/* ============================================
   Module: base.css
   ============================================ */

/* ============================================
   Base Styles
   ============================================ */

* {
  border-color: hsl(var(--border));
}

html,
body {
  overflow-x: hidden;
  width: 100%;
  box-sizing: border-box;
}

body {
  background-color: hsl(var(--background));
  color: hsl(var(--foreground));
  font-family: ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
  margin: 0;
  padding: 0;
}



/* ============================================
   Module: components.css
   ============================================ */

/* ============================================
   Component Styles - Card
   ============================================ */

.card {
  border-radius: calc(var(--radius));
  border: 1px solid hsl(var(--border));
  background-color: hsl(var(--card));
  color: hsl(var(--card-foreground));
  box-shadow: 0 1px 2px 0 hsl(var(--a11y-shadow) / 0.05);
}

.card-header {
  display: flex;
  flex-direction: column;
  gap: 0.375rem;
  padding: 1.5rem;
}

.card-title {
  font-size: 1.5rem;
  font-weight: 600;
  line-height: 1;
  letter-spacing: -0.025em;
  margin: 0;
}

.card-title-with-icon {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.card-title-icon {
  color: hsl(var(--dashboard-accent));
}

.card-description {
  font-size: 0.875rem;
  color: hsl(var(--muted-foreground));
  margin: 0;
}

.card-content {
  padding: 0 1.5rem 1.5rem;
}

/* Card Variants */
.card-border-accent {
  border-color: hsl(var(--dashboard-accent) / 0.3);
}

.card-mt {
  margin-top: 1.5rem;
}


/* ============================================
   Component Styles - Button
   ============================================ */

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  white-space: nowrap;
  border-radius: calc(var(--radius) - 2px);
  font-size: 0.875rem;
  font-weight: 500;
  transition: all 0.2s;
  outline: none;
  border: none;
  cursor: pointer;
  text-decoration: none;
  box-sizing: border-box;
}

.btn:focus-visible {
  outline: 2px solid hsl(var(--ring));
  outline-offset: 2px;
}

.btn:disabled {
  pointer-events: none;
  opacity: 0.5;
}

.btn svg {
  width: 1rem;
  height: 1rem;
  pointer-events: none;
  flex-shrink: 0;
  display: inline-block;
}

/* Button Variants */
.btn-default {
  height: 2.5rem;
  padding: 0.5rem 1rem;
  background-color: hsl(var(--dashboard-accent));
  color: hsl(0, 0%, 0%);
  font-weight: 600;
}

.btn-default:hover {
  background-color: hsl(var(--dashboard-accent) / 0.9);
}

.btn-default svg {
  color: hsl(0, 0%, 0%);
  stroke: hsl(0, 0%, 0%);
  fill: none;
}

.btn-outline {
  height: 2.5rem;
  padding: 0.5rem 1rem;
  border: 1px solid hsl(var(--input));
  background-color: hsl(var(--background));
  color: hsl(var(--foreground));
}

.btn-outline:hover {
  background-color: hsl(var(--accent));
  color: hsl(var(--accent-foreground));
}

.btn-outline-accent {
  height: 2.5rem;
  padding: 0.5rem 1rem;
  border: 1px solid hsl(var(--dashboard-accent));
  background-color: transparent;
  color: hsl(var(--dashboard-text));
  font-size: 0.875rem;
  font-weight: 500;
  box-sizing: border-box;
}

.btn-outline-accent:hover {
  background-color: hsl(var(--dashboard-accent) / 0.1);
  color: hsl(var(--dashboard-text));
  border-color: hsl(var(--dashboard-accent) / 0.6);
  box-shadow: 0 10px 15px -3px hsl(var(--dashboard-accent) / 0.1), 0 4px 6px -2px hsl(var(--dashboard-accent) / 0.1);
  transition: all 0.3s;
}

.btn-outline-danger {
  border-color: hsl(0 84% 60% / 0.5);
  color: hsl(0 84% 60%);
}

.btn-outline-danger:hover {
  background-color: hsl(0 84% 60% / 0.2);
}

.btn-ghost {
  height: 2.5rem;
  padding: 0.5rem 1rem;
  background-color: transparent;
  color: hsl(var(--foreground));
}

.btn-ghost:hover {
  background-color: hsl(var(--accent));
  color: hsl(var(--accent-foreground));
}

.btn-icon {
  height: 2.5rem;
  width: 2.5rem;
  padding: 0;
}

.password-toggle-btn {
  position: absolute;
  right: 0.75rem;
  top: 50%;
  transform: translateY(-50%);
  padding: 0;
  width: auto;
  height: auto;
}

/* ============================================
   Component Styles - Input
   ============================================ */

.input {
  display: flex;
  height: 2.5rem;
  width: 100%;
  border-radius: calc(var(--radius) - 2px);
  border: 1px solid hsl(var(--input));
  background-color: hsl(var(--background));
  color: hsl(var(--foreground));
  padding: 0.5rem 0.75rem;
  font-size: 0.875rem;
  transition: all 0.2s;
  outline: none;
  box-sizing: border-box;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
}

/* Ensure select elements match input styling exactly */
select.input {
  display: flex;
  height: 2.5rem;
  width: 100%;
  border-radius: calc(var(--radius) - 2px);
  border: 1px solid hsl(var(--input));
  background-color: hsl(var(--background));
  color: hsl(var(--foreground));
  padding: 0.5rem 0.75rem;
  font-size: 0.875rem;
  transition: all 0.2s;
  outline: none;
  box-sizing: border-box;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  cursor: pointer;
  /* Token-based chevron (no hardcoded colors) */
  background-image:
    linear-gradient(45deg, hsl(var(--foreground) / 0) 50%, hsl(var(--muted-foreground)) 50%),
    linear-gradient(135deg, hsl(var(--muted-foreground)) 50%, hsl(var(--foreground) / 0) 50%);
  background-repeat: no-repeat;
  background-position: right 0.75rem center;
  background-size: 0.5rem 0.5rem, 0.5rem 0.5rem;
  padding-right: 2.5rem;
}

.input::placeholder {
  color: hsl(var(--muted-foreground));
}

.input:focus-visible {
  outline: 2px solid hsl(var(--ring));
  outline-offset: 2px;
}

.input:disabled {
  cursor: not-allowed;
  opacity: 0.5;
}

/* Input Variants */
.input-dashboard {
  background-color: hsl(var(--dashboard-bg));
  border-color: hsl(var(--dashboard-border) / 0.3);
  color: hsl(var(--dashboard-text));
}

.password-input-wrapper {
  position: relative;
}

.password-input-wrapper .input {
  padding-right: 2.5rem;
}

.file-input-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border-width: 0;
}

/* ============================================
   Component Styles - Textarea
   ============================================ */

.textarea {
  display: flex;
  min-height: 5rem;
  width: 100%;
  border-radius: calc(var(--radius) - 2px);
  border: 1px solid hsl(var(--input));
  background-color: hsl(var(--background));
  color: hsl(var(--foreground));
  padding: 0.5rem 0.75rem;
  font-size: 0.875rem;
  font-family: inherit;
  transition: all 0.2s;
  outline: none;
  box-sizing: border-box;
  resize: vertical;
}

.textarea::placeholder {
  color: hsl(var(--muted-foreground));
}

.textarea:focus-visible {
  outline: 2px solid hsl(var(--ring));
  outline-offset: 2px;
}

.textarea:disabled {
  cursor: not-allowed;
  opacity: 0.5;
}

.textarea-dashboard {
  background-color: hsl(var(--dashboard-bg));
  border-color: hsl(var(--dashboard-border) / 0.3);
  color: hsl(var(--dashboard-text));
}

/* ============================================
   Component Styles - Dialog/Modal
   ============================================ */

.dialog-overlay {
  position: fixed;
  inset: 0;
  z-index: 50;
  background-color: hsl(var(--a11y-overlay) / 0.5);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem;
}

.dialog-content {
  background-color: hsl(var(--dashboard-card));
  border: 1px solid hsl(var(--dashboard-border) / 0.3);
  border-radius: calc(var(--radius));
  box-shadow: 0 10px 15px -3px hsl(var(--a11y-shadow) / 0.1), 0 4px 6px -2px hsl(var(--a11y-shadow) / 0.05);
  width: 100%;
  max-width: 32rem;
  max-height: 90vh;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
}

.dialog-header {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  padding: 1.5rem;
  border-bottom: 1px solid hsl(var(--dashboard-border) / 0.3);
}

.dialog-title {
  font-size: 1.25rem;
  font-weight: 600;
  line-height: 1;
  color: hsl(var(--dashboard-text));
  margin: 0;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.dialog-body {
  padding: 1rem 1.5rem;
  flex: 1;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.dialog-footer {
  display: flex;
  justify-content: flex-end;
  gap: 0.75rem;
  padding: 1.5rem;
  border-top: 1px solid hsl(var(--dashboard-border) / 0.3);
}

.dialog-close {
  position: absolute;
  top: 1rem;
  right: 1rem;
  background: transparent;
  border: none;
  cursor: pointer;
  padding: 0.5rem;
  border-radius: calc(var(--radius) - 2px);
  color: hsl(var(--muted-foreground));
  transition: all 0.2s;
}

.dialog-close:hover {
  background-color: hsl(var(--muted));
  color: hsl(var(--foreground));
}

/* ============================================
   Component Styles - Label
   ============================================ */

.label {
  font-size: 0.875rem;
  font-weight: 500;
  line-height: 1;
  margin-bottom: 0.5rem;
  display: block;
}

/* ============================================
   Component Styles - Tabs
   ============================================ */

.tabs {
  width: 100%;
}

.tabs-list {
  display: inline-flex;
  height: 2.5rem;
  align-items: center;
  justify-content: center;
  border-radius: 0.375rem;
  background-color: hsl(var(--dashboard-card));
  border: 1px solid hsl(var(--dashboard-border) / 0.3);
  padding: 0.25rem;
  color: hsl(var(--muted-foreground));
}

.tabs-trigger {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  white-space: nowrap;
  border-radius: 0.125rem;
  padding: 0.375rem 0.75rem;
  font-size: 0.875rem;
  font-weight: 500;
  transition: all 0.2s;
  outline: none;
  border: none;
  background: transparent;
  cursor: pointer;
  gap: 0.5rem;
  color: hsl(var(--muted-foreground));
}

.tabs-trigger:focus-visible {
  outline: 2px solid hsl(var(--ring));
  outline-offset: 2px;
}

.tabs-trigger[data-state="active"] {
  background-color: hsl(var(--dashboard-accent));
  color: hsl(0, 0%, 0%);
  box-shadow: 0 1px 2px 0 hsl(var(--a11y-shadow) / 0.05);
  border-radius: 0.375rem;
}

.tabs-trigger[data-state="active"] svg {
  color: hsl(0, 0%, 0%);
}

.tabs-trigger:disabled {
  pointer-events: none;
  opacity: 0.5;
}

.tabs-trigger svg {
  width: 1rem;
  height: 1rem;
}

.tabs-content {
  margin-top: 1.5rem;
  outline: none;
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

.tabs-content:focus-visible {
  outline: 2px solid hsl(var(--ring));
  outline-offset: 2px;
}

/* ============================================
   Component Styles - Switch
   ============================================ */

.switch {
  position: relative;
  display: inline-flex;
  height: 1.5rem;
  width: 2.75rem;
  flex-shrink: 0;
  cursor: pointer;
  align-items: center;
  border-radius: 9999px;
  border: 2px solid transparent;
  transition: all 0.2s;
  outline: none;
}

.switch:focus-visible {
  outline: 2px solid hsl(var(--ring));
  outline-offset: 2px;
}

.switch:disabled {
  cursor: not-allowed;
  opacity: 0.5;
}

.switch[data-state="checked"] {
  background-color: hsl(var(--primary));
}

.switch[data-state="unchecked"] {
  background-color: hsl(var(--input));
}

.switch-thumb {
  pointer-events: none;
  display: block;
  height: 1.25rem;
  width: 1.25rem;
  border-radius: 9999px;
  background-color: hsl(var(--background));
  box-shadow: 0 2px 4px 0 hsl(var(--a11y-shadow) / 0.2);
  transition: transform 0.2s;
}

.switch[data-state="checked"] .switch-thumb {
  transform: translateX(1.25rem);
}

.switch[data-state="unchecked"] .switch-thumb {
  transform: translateX(0);
}

/* ============================================
   Component Styles - Badge
   ============================================ */

.badge {
  display: inline-flex;
  align-items: center;
  border-radius: 9999px;
  border: 1px solid transparent;
  padding: 0.125rem 0.625rem;
  font-size: 0.75rem;
  font-weight: 600;
  transition: all 0.2s;
  outline: none;
}

.badge:focus {
  outline: 2px solid hsl(var(--ring));
  outline-offset: 2px;
}

.badge-default {
  border-color: transparent;
  background-color: hsl(var(--primary));
  color: hsl(var(--primary-foreground));
}

.badge-default:hover {
  background-color: hsl(var(--primary) / 0.8);
}

.badge-outline {
  color: hsl(var(--foreground));
  border-color: hsl(var(--border));
}

.badge-outline.badge-connected {
  background-color: hsl(142 71% 45% / 0.2);
  color: hsl(142 71% 45%);
  border-color: hsl(142 71% 45% / 0.3);
}

/* ============================================
   Component Styles - Select
   ============================================ */

.select {
  position: relative;
}

.select-trigger {
  display: flex;
  height: 2.5rem;
  width: 100%;
  align-items: center;
  justify-content: space-between;
  border-radius: calc(var(--radius) - 2px);
  border: 1px solid hsl(var(--input));
  background-color: hsl(var(--background));
  padding: 0.5rem 0.75rem;
  font-size: 0.875rem;
  transition: all 0.2s;
  outline: none;
  cursor: pointer;
  gap: 0.5rem;
}

.select-trigger:focus-visible {
  outline: 2px solid hsl(var(--ring));
  outline-offset: 2px;
}

.select-trigger:disabled {
  cursor: not-allowed;
  opacity: 0.5;
}

.select-content {
  position: absolute;
  z-index: 50;
  min-width: 8rem;
  overflow: hidden;
  border-radius: calc(var(--radius) - 2px);
  border: 1px solid hsl(var(--border) / 0.5);
  background-color: hsl(var(--popover));
  color: hsl(var(--popover-foreground));
  box-shadow: 0 4px 6px -1px hsl(var(--a11y-shadow) / 0.1), 0 2px 4px -1px hsl(var(--a11y-shadow) / 0.06);
  margin-top: 0.25rem;
}

.select-item {
  position: relative;
  display: flex;
  cursor: pointer;
  user-select: none;
  align-items: center;
  border-radius: calc(var(--radius) - 4px);
  padding: 0.5rem 2rem 0.5rem 0.75rem;
  font-size: 0.875rem;
  outline: none;
}

.select-item:hover {
  background-color: hsl(var(--accent));
  color: hsl(var(--accent-foreground));
}

.select-item[data-highlighted] {
  background-color: hsl(var(--accent));
  color: hsl(var(--accent-foreground));
}

/* ============================================
   Component Styles - Separator
   ============================================ */

.separator {
  height: 1px;
  width: 100%;
  background-color: hsl(var(--dashboard-border) / 0.3);
}

/* ============================================
   Component Styles - Avatar
   ============================================ */

.avatar {
  position: relative;
  display: flex;
  height: 2.5rem;
  width: 2.5rem;
  flex-shrink: 0;
  overflow: hidden;
  border-radius: 9999px;
}

.avatar-lg {
  height: 6rem;
  width: 6rem;
}

.avatar-image {
  aspect-ratio: 1;
  height: 100%;
  width: 100%;
  object-fit: cover;
}

.avatar-fallback {
  display: flex;
  height: 100%;
  width: 100%;
  align-items: center;
  justify-content: center;
  border-radius: 9999px;
  background-color: hsl(var(--dashboard-accent));
  color: hsl(0, 0%, 0%);
  font-size: 0.875rem;
  font-weight: 600;
}

.avatar-lg .avatar-fallback {
  font-size: 1.5rem;
}

.avatar-border-accent {
  border: 2px solid hsl(var(--dashboard-accent));
}

/* ============================================
   Component Styles - Stat Card (Shared)
   ============================================ */
.stat-card {
  border-radius: calc(var(--radius));
  border: 1px solid hsl(var(--dashboard-border) / 0.3);
  background-color: hsl(var(--dashboard-card));
  padding: 1rem;
}

.stat-card-icon {
  width: 1.75rem;
  height: 1.75rem;
  padding: 0.375rem;
  border-radius: calc(var(--radius) - 2px);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.stat-card-icon svg {
  width: 0.875rem;
  height: 0.875rem;
}

.stat-card-content {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.stat-card-text {
  font-size: 0.875rem;
  color: hsl(var(--muted-foreground));
  margin: 0;
}

.stat-card-value {
  font-size: 1.5rem;
  font-weight: 700;
  margin: 0;
}

.stat-card-value-sm {
  font-size: 1.125rem;
  font-weight: 600;
}

/* Stat Card Variants */
.stat-card-accent {
  border-color: hsl(var(--dashboard-accent) / 0.3);
}

.stat-card-accent .stat-card-icon {
  background-color: hsl(var(--dashboard-accent) / 0.2);
  color: hsl(var(--dashboard-accent));
}

.stat-card-accent .stat-card-icon svg {
  color: hsl(var(--dashboard-accent));
}

.stat-card-accent .stat-card-value {
  color: hsl(var(--dashboard-text));
}

.stat-card-green {
  border-color: hsl(142 71% 45% / 0.3);
}

.stat-card-green .stat-card-icon {
  background-color: hsl(142 71% 45% / 0.2);
}

.stat-card-green .stat-card-icon svg {
  color: hsl(142 71% 45%);
}

.stat-card-green .stat-card-value {
  color: hsl(142 71% 45%);
}

.stat-card-blue {
  border-color: hsl(217 91% 60% / 0.3);
}

.stat-card-blue .stat-card-icon {
  background-color: hsl(217 91% 60% / 0.2);
}

.stat-card-blue .stat-card-icon svg {
  color: hsl(217 91% 60%);
}

.stat-card-blue .stat-card-value {
  color: hsl(217 91% 60%);
}

.stat-card-purple {
  border-color: hsl(262 83% 58% / 0.3);
}

.stat-card-purple .stat-card-icon {
  background-color: hsl(262 83% 58% / 0.2);
}

.stat-card-purple .stat-card-icon svg {
  color: hsl(262 83% 58%);
}

.stat-card-purple .stat-card-value {
  color: hsl(262 83% 58%);
}

.stat-card-yellow {
  border-color: hsl(45 100% 50% / 0.3);
}

.stat-card-yellow .stat-card-icon {
  background-color: hsl(45 100% 50% / 0.2);
}

.stat-card-yellow .stat-card-icon svg {
  color: hsl(45 100% 50%);
}

.stat-card-yellow .stat-card-value {
  color: hsl(45 100% 50%);
}

.stat-card-red {
  border-color: hsl(0 84% 60% / 0.3);
}

.stat-card-red .stat-card-icon {
  background-color: hsl(0 84% 60% / 0.2);
}

.stat-card-red .stat-card-icon svg {
  color: hsl(0 84% 60%);
}

.stat-card-red .stat-card-value {
  color: hsl(0 84% 60%);
}

/* ============================================
   Settings Page Specific Styles
   ============================================ */

.settings-page {
  display: flex;
  height: 100vh;
  background-color: hsl(var(--dashboard-bg));
  overflow: hidden;
}

.settings-content {
  flex: 1;
  overflow-y: auto;
  padding: 2rem;
  padding-right: 6rem;
}

.settings-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 2rem;
}

.settings-header-left {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.settings-header h1 {
  font-size: 1.5rem;
  font-weight: 700;
  color: hsl(var(--dashboard-text));
  margin: 0;
}

.settings-header svg {
  width: 1.5rem;
  height: 1.5rem;
  color: hsl(var(--dashboard-accent));
}

.settings-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1rem;
  margin-bottom: 1.5rem;
}

.settings-section {
  margin-bottom: 1.5rem;
}

.section-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1rem;
}

.settings-section-full {
  grid-column: 1 / -1;
}

.settings-switch-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.75rem;
  border-radius: calc(var(--radius) - 2px);
  border: 1px solid hsl(var(--dashboard-border) / 0.3);
  background-color: hsl(var(--dashboard-bg));
  margin-bottom: 0.5rem;
}

.settings-switch-row-content {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.settings-switch-row-content svg {
  width: 1.25rem;
  height: 1.25rem;
  color: hsl(var(--muted-foreground));
}

.settings-switch-row-text {
  display: flex;
  flex-direction: column;
}

.settings-switch-row-title {
  font-weight: 500;
  color: hsl(var(--dashboard-text));
  margin: 0;
}

.settings-switch-row-description {
  font-size: 0.875rem;
  color: hsl(var(--muted-foreground));
  margin: 0;
}

.settings-switch-row-danger {
  border-color: hsl(0 84% 60% / 0.3);
}

.settings-theme-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.75rem;
}

.settings-theme-button {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.75rem;
  border-radius: calc(var(--radius) - 2px);
  border: 1px solid hsl(var(--dashboard-border) / 0.3);
  background: transparent;
  color: hsl(var(--muted-foreground));
  cursor: pointer;
  transition: all 0.2s;
  font-size: 0.875rem;
}

.settings-theme-button:hover {
  border-color: hsl(var(--dashboard-accent) / 0.5);
}

.settings-theme-button.active {
  border-color: hsl(var(--dashboard-accent));
  background-color: hsl(var(--dashboard-accent) / 0.2);
  color: hsl(var(--dashboard-accent));
}

.settings-theme-button svg {
  width: 1.25rem;
  height: 1.25rem;
}

.platform-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.6rem;
  background-color: hsl(var(--dashboard-bg));
  border-radius: calc(var(--radius) - 2px);
  border: 1px solid hsl(var(--dashboard-border) / 0.3);
  transition: opacity 0.2s ease;
}

.platform-row.platform-row-removing {
  opacity: 0.55;
  pointer-events: none;
}

.spinning {
  animation: hx-spin 0.9s linear infinite;
  transform-origin: 50% 50%;
}

@keyframes hx-spin {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
}

.platform-row-actions {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.platform-name {
  font-weight: 500;
}

.platform-disconnect-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  padding: 0.5rem 0.875rem;
  font-size: 0.875rem;
  font-weight: 500;
  white-space: nowrap;
  color: hsl(0 72% 58%);
  background-color: hsl(0 72% 58% / 0.1);
  border: 1px solid hsl(0 72% 58% / 0.3);
  border-radius: calc(var(--radius) - 2px);
  transition: all 0.2s ease;
  cursor: pointer;
}

.platform-disconnect-btn:hover {
  background-color: hsl(0 72% 58% / 0.15);
  border-color: hsl(0 72% 58% / 0.5);
  color: hsl(0 72% 50%);
  transform: translateY(-1px);
  box-shadow: 0 2px 8px hsl(0 72% 58% / 0.2);
}

.platform-disconnect-btn:active {
  transform: translateY(0);
  box-shadow: 0 1px 4px hsl(0 72% 58% / 0.15);
}

.platform-disconnect-btn:disabled {
  opacity: 0.6;
  cursor: not-allowed;
  transform: none;
}

.platform-disconnect-btn svg {
  width: 14px;
  height: 14px;
  stroke-width: 2.5;
}

.platform-name[data-platform="meta"] {
  color: hsl(217 91% 60%);
}

.platform-name[data-platform="google_ads"] {
  color: hsl(142 71% 45%);
}

.platform-name[data-platform="tiktok_ads"] {
  color: hsl(var(--dashboard-text));
}

.platform-name[data-platform="pinterest"] {
  color: hsl(0 84% 60%);
}

/* ============================================
   Utility Classes
   ============================================ */



/* ============================================
   Module: utilities.css
   ============================================ */

/* Text Utilities */
.text-dashboard-text {
  color: hsl(var(--dashboard-text));
}

.text-dashboard-text-muted {
  color: hsl(var(--dashboard-text-muted));
}

.text-xs-muted {
  font-size: 0.75rem;
  color: hsl(var(--muted-foreground));
  margin: 0;
}

.text-right {
  text-align: right;
}

.text-center {
  text-align: center;
}

.text-left {
  text-align: left;
}

/* Background Utilities */
.bg-dashboard-bg {
  background-color: hsl(var(--dashboard-bg));
}

.bg-dashboard-card {
  background-color: hsl(var(--dashboard-card));
}

/* Border Utilities */
.border-dashboard-border {
  border-color: hsl(var(--dashboard-border));
}

.border-dashboard-accent {
  border-color: hsl(var(--dashboard-accent));
}

/* Spacing Utilities */
.space-y-2 > * + * {
  margin-top: 0.5rem;
}

.space-y-4 > * + * {
  margin-top: 1rem;
}

.space-y-6 > * + * {
  margin-top: 1.5rem;
}

.gap-2 {
  gap: 0.5rem;
}

.gap-3 {
  gap: 0.75rem;
}

.gap-4 {
  gap: 1rem;
}

.gap-6 {
  gap: 1.5rem;
}

/* Flex Utilities */
.flex {
  display: flex;
}

.flex-row-gap {
  display: flex;
  align-items: center;
  gap: 1.5rem;
}

.flex-gap-sm {
  display: flex;
  gap: 0.75rem;
}

.items-center {
  align-items: center;
}

.justify-between {
  justify-content: space-between;
}

/* Width Utilities */
.w-full {
  width: 100%;
}

/* Display Utilities */
.hidden {
  display: none;
}

/* ============================================
   Page Layout - Shared Components
   ============================================ */



/* ============================================
   Module: layout.css
   ============================================ */

/* Page Container - Shared by all pages */
.page-container {
  min-height: 100vh;
  background-color: hsl(var(--dashboard-bg));
  color: hsl(var(--dashboard-text));
  padding: 2rem;
  padding-right: 6rem;
  box-sizing: border-box;
  max-width: 100%;
  overflow-x: hidden;
}

.page-content {
  max-width: 100%;
}

.page-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 2rem;
}

.page-header-left {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.sidebar-menu-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  border-radius: calc(var(--radius) - 2px);
  background-color: transparent;
  color: hsl(var(--dashboard-text));
  border: none;
  cursor: pointer;
  transition: all 0.2s;
  flex-shrink: 0;
  padding: 0;
}

.sidebar-menu-btn:hover {
  background-color: hsl(var(--dashboard-accent) / 0.1);
  color: hsl(var(--dashboard-accent));
}

.sidebar-menu-btn svg {
  width: 1.25rem;
  height: 1.25rem;
  stroke: currentColor;
  color: inherit;
}

.page-header-icon {
  width: 1.5rem;
  height: 1.5rem;
  color: hsl(var(--dashboard-accent));
}

.page-header h1 {
  font-size: 1.5rem;
  font-weight: 700;
  color: hsl(var(--dashboard-text));
  margin: 0;
}

.stats-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1rem;
  margin-bottom: 1.5rem;
}

/* ============================================
   Feedback Page Styles
   ============================================ */

/* Feedback page uses shared page layout classes - no duplicates */

.feedback-resolution-card {
  padding: 1rem;
  margin-bottom: 1.5rem;
}

.feedback-resolution-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 0.5rem;
}

.feedback-resolution-label {
  font-size: 0.875rem;
  color: hsl(var(--muted-foreground));
}

.feedback-resolution-value {
  color: hsl(var(--dashboard-accent));
  font-weight: 600;
}

.progress-wrapper {
  width: 100%;
}

.progress-bar {
  height: 0.5rem;
  width: 100%;
  background-color: hsl(var(--muted));
  border-radius: calc(var(--radius) - 2px);
  overflow: hidden;
}

.progress-fill {
  height: 100%;
  width: 0%;
  background-color: hsl(var(--dashboard-accent));
  transition: width 0.3s ease;
}

.feedback-filters {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-bottom: 1.5rem;
  flex-wrap: nowrap;
}

.feedback-search-wrapper {
  position: relative;
  flex: 1;
  min-width: 0;
  max-width: 100%;
  display: flex;
  align-items: center;
}

.feedback-search-icon {
  position: absolute;
  left: 0.75rem;
  top: 50%;
  transform: translateY(-50%);
  width: 1rem;
  height: 1rem;
  color: hsl(var(--muted-foreground));
  pointer-events: none;
  z-index: 1;
}

.feedback-search-input {
  padding-left: 2.5rem;
  width: 100%;
  min-width: 0;
}

.feedback-filter-wrapper {
  position: relative;
  display: flex;
  align-items: center;
  flex-shrink: 0;
}

.feedback-filter-icon {
  position: absolute;
  left: 0.75rem;
  top: 50%;
  transform: translateY(-50%);
  width: 1rem;
  height: 1rem;
  color: hsl(var(--muted-foreground));
  pointer-events: none;
  z-index: 1;
}

select.input.feedback-filter-select {
  width: 140px;
  padding-left: 2.5rem;
}

select.input.feedback-filter-type {
  width: 160px;
  padding-left: 2.5rem;
}

.feedback-list {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.feedback-item {
  transition: all 0.2s;
}

.feedback-item:hover {
  border-color: hsl(var(--dashboard-accent) / 0.5);
}

.feedback-item-content {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
  padding: 1.25rem;
}

.feedback-vote-section {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.25rem;
}

.feedback-vote-btn {
  width: 2rem;
  height: 2rem;
  padding: 0;
}

.feedback-vote-btn:hover {
  background-color: hsl(var(--dashboard-accent) / 0.2);
  color: hsl(var(--dashboard-accent));
}

.feedback-vote-count {
  font-size: 0.875rem;
  font-weight: 500;
  color: hsl(var(--dashboard-accent));
}

.feedback-item-main {
  flex: 1;
  min-width: 0;
}

.feedback-item-badges {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-wrap: wrap;
  margin-bottom: 0.5rem;
}

.feedback-type-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  background: transparent;
  border: 1px solid currentColor;
}

.feedback-type-badge[data-type="bug"] {
  color: hsl(0 84% 60%);
}

.feedback-type-badge[data-type="feature"] {
  color: hsl(45 100% 50%);
}

.feedback-type-badge[data-type="improvement"] {
  color: hsl(217 91% 60%);
}

.feedback-type-badge[data-type="question"] {
  color: hsl(280 100% 70%);
}

.feedback-type-badge[data-type="praise"] {
  color: hsl(var(--dashboard-accent));
}

.feedback-priority-badge {
  font-size: 0.75rem;
}

.feedback-priority-badge[data-priority="high"] {
  background-color: hsl(0 84% 60% / 0.2);
  color: hsl(0 84% 60%);
  border-color: hsl(0 84% 60%);
}

.feedback-priority-badge[data-priority="medium"] {
  background-color: hsl(45 100% 50% / 0.2);
  color: hsl(45 100% 50%);
  border-color: hsl(45 100% 50%);
}

.feedback-priority-badge[data-priority="low"] {
  background-color: hsl(142 71% 45% / 0.2);
  color: hsl(142 71% 45%);
  border-color: hsl(142 71% 45%);
}

.feedback-item-title {
  font-size: 0.875rem;
  font-weight: 600;
  color: hsl(var(--dashboard-text));
  margin: 0 0 0.25rem 0;
}

.feedback-item-message {
  font-size: 0.875rem;
  color: hsl(var(--muted-foreground));
  margin: 0 0 0.75rem 0;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.feedback-item-meta {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.75rem;
  color: hsl(var(--muted-foreground));
}

.feedback-item-actions {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.feedback-status-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
}

.feedback-status-badge[data-status="pending"] {
  background-color: hsl(45 100% 50% / 0.2);
  color: hsl(45 100% 50%);
  border-color: hsl(45 100% 50%);
}

.feedback-status-badge[data-status="read"] {
  background-color: hsl(217 91% 60% / 0.2);
  color: hsl(217 91% 60%);
  border-color: hsl(217 91% 60%);
}

.feedback-status-badge[data-status="in-progress"] {
  background-color: hsl(0 84% 60% / 0.2);
  color: hsl(0 84% 60%);
  border-color: hsl(0 84% 60%);
}

.feedback-status-badge[data-status="resolved"] {
  background-color: hsl(142 71% 45% / 0.2);
  color: hsl(142 71% 45%);
  border-color: hsl(142 71% 45%);
}

.feedback-more-btn {
  width: 2rem;
  height: 2rem;
  padding: 0;
}

.feedback-empty {
  padding: 3rem;
  text-align: center;
}

.feedback-empty-icon {
  width: 3rem;
  height: 3rem;
  color: hsl(var(--muted-foreground));
  opacity: 0.5;
  margin: 0 auto 1rem;
}

.feedback-empty-text {
  color: hsl(var(--muted-foreground));
  margin: 0;
}

.dialog-title-icon {
  color: hsl(var(--dashboard-accent));
}

/* ============================================
   Tasks Page Styles
   ============================================ */

/* Tasks page uses shared page layout classes - no duplicates */

.tasks-main-layout {
  display: flex;
  gap: 1.5rem;
  height: calc(100vh - 16rem);
}

.tasks-sidebar {
  width: 18rem;
  background-color: hsl(var(--dashboard-card));
  border: 1px solid hsl(var(--dashboard-border) / 0.3);
  border-radius: calc(var(--radius));
  padding: 1rem;
  overflow-y: auto;
  flex-shrink: 0;
}

.tasks-sidebar-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 1rem;
}

.tasks-sidebar-title {
  font-weight: 600;
  color: hsl(var(--dashboard-text));
  margin: 0;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.tasks-sidebar-icon {
  width: 1rem;
  height: 1rem;
  color: hsl(var(--dashboard-accent));
}

.tasks-new-list-form {
  margin-bottom: 1rem;
  padding: 0.75rem;
  background-color: hsl(var(--dashboard-bg));
}

.tasks-new-list-form .card-content {
  padding: 0;
}

.tasks-lists {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.tasks-list-item {
  padding: 0.75rem;
  border-radius: calc(var(--radius) - 2px);
  border: 1px solid transparent;
  background-color: hsl(var(--dashboard-bg));
  cursor: pointer;
  transition: all 0.2s;
}

.tasks-list-item:hover {
  border-color: hsl(var(--dashboard-border) / 0.5);
}

.tasks-list-item-active {
  background-color: hsl(var(--dashboard-accent) / 0.1);
  border-color: hsl(var(--dashboard-accent));
}

.tasks-list-item-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  margin-bottom: 0.5rem;
}

.tasks-list-item-main {
  flex: 1;
  min-width: 0;
}

.tasks-list-item-name-row {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.tasks-list-color {
  width: 0.5rem;
  height: 0.5rem;
  border-radius: 50%;
  flex-shrink: 0;
  background-color: var(--list-color, hsl(var(--workspace-color-1)));
}

.tasks-list-color-large {
  width: 0.75rem;
  height: 0.75rem;
}

.tasks-list-name {
  font-weight: 500;
  color: hsl(var(--dashboard-text));
  font-size: 0.875rem;
}

.tasks-list-actions {
  display: flex;
  align-items: center;
  gap: 0.25rem;
}

.tasks-list-progress {
  margin-top: 0.5rem;
}

.tasks-list-progress-info {
  display: flex;
  justify-content: space-between;
  font-size: 0.75rem;
  margin-bottom: 0.25rem;
}

.tasks-list-pending {
  color: hsl(var(--muted-foreground));
}

.tasks-list-progress-value {
  color: hsl(var(--dashboard-accent));
}

.tasks-main {
  flex: 1;
  background-color: hsl(var(--dashboard-card));
  border: 1px solid hsl(var(--dashboard-border) / 0.3);
  border-radius: calc(var(--radius));
  padding: 1.5rem;
  overflow-y: auto;
}

.tasks-list-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 1.5rem;
}

.tasks-list-header-left {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.tasks-list-header-title-row {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.tasks-list-title {
  font-size: 1.25rem;
  font-weight: 700;
  color: hsl(var(--dashboard-text));
  margin: 0;
}

.tasks-list {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.tasks-task-item {
  transition: all 0.2s;
  background-color: hsl(var(--dashboard-bg));
}

.tasks-task-item:hover {
  border-color: hsl(var(--dashboard-accent) / 0.5);
}

.tasks-task-completed {
  opacity: 0.6;
}

.tasks-task-content {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
  padding: 1rem;
}

.tasks-task-checkbox-wrapper {
  padding-top: 0.125rem;
}

.tasks-task-checkbox {
  width: 1.125rem;
  height: 1.125rem;
  cursor: pointer;
  accent-color: hsl(var(--dashboard-accent));
}

.tasks-task-main {
  flex: 1;
  min-width: 0;
}

.tasks-task-header {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-wrap: wrap;
  margin-bottom: 0.25rem;
}

.tasks-task-title {
  font-weight: 500;
  color: hsl(var(--dashboard-text));
}

.tasks-task-title-completed {
  text-decoration: line-through;
  color: hsl(var(--muted-foreground));
}

.tasks-task-badges {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-wrap: wrap;
}

.tasks-task-description {
  font-size: 0.875rem;
  color: hsl(var(--muted-foreground));
  margin: 0 0 0.5rem 0;
}

.tasks-task-meta {
  display: flex;
  align-items: center;
  gap: 1rem;
  font-size: 0.75rem;
  color: hsl(var(--muted-foreground));
  flex-wrap: wrap;
}

.tasks-task-meta-item {
  display: flex;
  align-items: center;
  gap: 0.25rem;
}

.tasks-task-overdue {
  color: hsl(0 84% 60%);
}

.tasks-task-status {
  display: flex;
  align-items: center;
  gap: 0.25rem;
}

.tasks-status-icon {
  width: 0.75rem;
  height: 0.75rem;
}

.tasks-task-actions {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

/* ============================================
   Tasks Page - Status Dropdown
   ============================================ */

.tasks-status-dropdown {
  position: relative;
}

.tasks-status-btn {
  height: 2rem;
  padding: 0 0.5rem;
  display: flex;
  align-items: center;
  gap: 0.25rem;
  font-size: 0.875rem;
}

.tasks-status-btn-icon {
  width: 1rem;
  height: 1rem;
}

.tasks-status-btn-icon[data-status="completed"],
.tasks-status-btn-icon:has(path[d*="22 11.08"]) {
  color: hsl(142 71% 45%);
}

.tasks-status-btn-icon[data-status="in-progress"],
.tasks-status-btn-icon:has(polyline[points*="12 6 12 12"]) {
  color: hsl(var(--dashboard-accent));
}

.tasks-status-btn-icon[data-status="not-started"],
.tasks-status-btn-icon:has(circle):not(:has(polyline)):not(:has(path[d*="22 11.08"])) {
  color: hsl(var(--muted-foreground));
}

.tasks-status-chevron {
  width: 0.75rem;
  height: 0.75rem;
  color: hsl(var(--muted-foreground));
}

.tasks-status-menu {
  min-width: 10rem;
  background-color: hsl(var(--dashboard-card));
  border-color: hsl(var(--dashboard-border) / 0.5);
}

.tasks-status-menu-label {
  padding: 0.5rem 0.75rem;
  font-weight: 600;
  margin-bottom: 0;
}

.tasks-status-menu .select-item {
  padding: 0.5rem 0.75rem;
  gap: 0.5rem;
  color: hsl(var(--dashboard-text));
}

.tasks-status-menu .select-item:hover {
  background-color: hsl(var(--dashboard-accent) / 0.1);
  color: hsl(var(--dashboard-text));
}

.tasks-status-menu .select-item svg {
  width: 1rem;
  height: 1rem;
  flex-shrink: 0;
}

.tasks-status-option[data-status="not-started"] svg {
  color: hsl(var(--muted-foreground));
}

.tasks-status-option[data-status="in-progress"] svg {
  color: hsl(var(--dashboard-accent));
}

.tasks-status-option[data-status="completed"] svg {
  color: hsl(142 71% 45%);
}

/* ============================================
   Connections Page
   ============================================ */

.connections-workspace-bar {
  margin-bottom: 1rem;
  background-color: hsl(var(--dashboard-bg));
  border: 1px solid hsl(var(--dashboard-border) / 0.2);
  border-radius: 1rem;
  padding: 0.25rem;
}

.connections-workspace-content {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
}

.connections-workspace-select {
  position: relative;
  z-index: 10;
}

.connections-workspace-form {
  display: inline-block;
}

.connections-workspace-trigger {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.5rem 1rem;
  border-radius: 0.75rem;
  background-color: hsl(var(--dashboard-card));
  border: 1px solid transparent;
  color: hsl(var(--dashboard-text));
  cursor: pointer;
  transition: all 0.3s;
  position: relative;
}

.connections-workspace-trigger:hover {
  background-color: hsl(var(--dashboard-accent) / 0.1);
  border-color: hsl(var(--dashboard-accent) / 0.3);
}

.connections-workspace-avatar {
  width: 2rem;
  height: 2rem;
  border-radius: 0.5rem;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  margin: 0;
  background-color: hsl(var(--workspace-color));
}

.connections-workspace-avatar[data-workspace-color="1"] {
  background-color: hsl(var(--workspace-color-1));
}

.connections-workspace-avatar[data-workspace-color="2"] {
  background-color: hsl(var(--workspace-color-2));
}

.connections-workspace-avatar[data-workspace-color="3"] {
  background-color: hsl(var(--workspace-color-3));
}

.connections-workspace-avatar[data-workspace-color="4"] {
  background-color: hsl(var(--workspace-color-4));
}

.connections-workspace-avatar[data-workspace-color="5"] {
  background-color: hsl(var(--workspace-color-5));
}

.connections-workspace-avatar[data-workspace-color="6"] {
  background-color: hsl(var(--workspace-color-6));
}

.connections-workspace-avatar[data-workspace-color="7"] {
  background-color: hsl(var(--workspace-color-7));
}

.connections-workspace-avatar[data-workspace-color="8"] {
  background-color: hsl(var(--workspace-color-8));
}

.connections-workspace-avatar-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.connections-workspace-avatar-letter {
  font-size: 0.875rem;
  font-weight: 700;
  color: hsl(0, 0%, 0%);
}

.connections-workspace-text {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  text-align: left;
  gap: 0.125rem;
  margin: 0;
}

.connections-workspace-label {
  font-size: 0.625rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: hsl(var(--dashboard-text-muted));
  line-height: 1;
  margin: 0;
}

.connections-workspace-name {
  font-size: 0.875rem;
  font-weight: 600;
  color: hsl(var(--dashboard-text));
  line-height: 1;
  margin: 0;
}

.connections-workspace-chevron {
  width: 1rem;
  height: 1rem;
  color: hsl(var(--dashboard-text-muted));
  margin-left: 0.25rem;
  transition: color 0.3s;
  flex-shrink: 0;
}

.connections-workspace-trigger:hover .connections-workspace-chevron {
  color: hsl(var(--dashboard-accent));
}

.connections-workspace-dropdown {
  position: absolute;
  top: calc(100% + 0.5rem);
  left: 0;
  width: 13.75rem;
  background-color: hsl(var(--dashboard-card));
  border: 1px solid hsl(var(--dashboard-border) / 0.5);
  border-radius: 0.75rem;
  box-shadow: 0 20px 25px -5px hsl(var(--a11y-shadow) / 0.1), 0 10px 10px -5px hsl(var(--a11y-shadow) / 0.04);
  padding: 0.25rem;
  z-index: 50;
  display: none;
  overflow: hidden;
}

.connections-workspace-dropdown.show {
  display: block;
}

.connections-workspace-dropdown-item {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.25rem 0.5rem;
  margin: 0.125rem 0.25rem;
  border-radius: 0.5rem;
  color: hsl(var(--dashboard-text));
  cursor: pointer;
  transition: all 0.2s;
}

.connections-workspace-dropdown-item:hover {
  background-color: hsl(var(--dashboard-accent) / 0.1);
  color: hsl(var(--dashboard-accent));
}

.connections-workspace-dropdown-avatar {
  width: 1.5rem;
  height: 1.5rem;
  border-radius: 0.375rem;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  background-color: hsl(var(--workspace-color));
}

.connections-workspace-dropdown-avatar[data-workspace-color="1"] {
  background-color: hsl(var(--workspace-color-1));
}

.connections-workspace-dropdown-avatar[data-workspace-color="2"] {
  background-color: hsl(var(--workspace-color-2));
}

.connections-workspace-dropdown-avatar[data-workspace-color="3"] {
  background-color: hsl(var(--workspace-color-3));
}

.connections-workspace-dropdown-avatar[data-workspace-color="4"] {
  background-color: hsl(var(--workspace-color-4));
}

.connections-workspace-dropdown-avatar[data-workspace-color="5"] {
  background-color: hsl(var(--workspace-color-5));
}

.connections-workspace-dropdown-avatar[data-workspace-color="6"] {
  background-color: hsl(var(--workspace-color-6));
}

.connections-workspace-dropdown-avatar[data-workspace-color="7"] {
  background-color: hsl(var(--workspace-color-7));
}

.connections-workspace-dropdown-avatar[data-workspace-color="8"] {
  background-color: hsl(var(--workspace-color-8));
}

.connections-workspace-dropdown-avatar-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.connections-workspace-dropdown-avatar-letter {
  font-size: 0.75rem;
  font-weight: 700;
  color: hsl(0, 0%, 0%);
}

.connections-workspace-dropdown-name {
  font-size: 0.875rem;
  color: inherit;
}

.connections-manage-btn {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.5rem 1rem;
  border-radius: 0.75rem;
  background-color: hsl(var(--dashboard-card));
  border: 1px solid transparent;
  color: hsl(var(--dashboard-text));
  cursor: pointer;
  transition: all 0.3s;
  text-decoration: none;
}

.connections-manage-btn:hover {
  background-color: hsl(var(--dashboard-accent) / 0.1);
  border-color: hsl(var(--dashboard-accent) / 0.3);
}

.connections-manage-icon {
  width: 2rem;
  height: 2rem;
  border-radius: 0.5rem;
  background-color: hsl(var(--dashboard-accent) / 0.2);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.connections-manage-icon svg {
  width: 1rem;
  height: 1rem;
  color: hsl(var(--dashboard-accent));
}

.connections-manage-text {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  text-align: left;
  gap: 0.125rem;
  margin: 0;
}

.connections-manage-label {
  font-size: 0.625rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: hsl(var(--dashboard-text-muted));
  line-height: 1;
  margin: 0;
}

.connections-manage-name {
  font-size: 0.875rem;
  font-weight: 600;
  color: hsl(var(--dashboard-text));
  line-height: 1;
  margin: 0;
}

.connections-description {
  margin-bottom: 2rem;
  max-width: 48rem;
  font-size: 0.875rem;
}

.connections-hive-card {
  margin-bottom: 1.5rem;
  background: linear-gradient(to right, hsl(var(--dashboard-card)), hsl(var(--dashboard-card)), hsl(var(--dashboard-accent) / 0.1));
  border-color: hsl(var(--dashboard-accent) / 0.5);
  cursor: pointer;
  transition: all 0.3s;
  position: relative;
  overflow: hidden;
  display: block;
  text-decoration: none;
  color: inherit;
}

.connections-hive-card > .card-content {
  padding: 0;
}

.connections-hive-card:hover {
  border-color: hsl(var(--dashboard-accent));
  box-shadow: 0 20px 25px -5px hsl(var(--a11y-shadow) / 0.1), 0 10px 10px -5px hsl(var(--a11y-shadow) / 0.04), 0 0 30px -5px hsl(var(--dashboard-accent) / 0.3);
  transform: translateY(-0.25rem);
}

.connections-hive-content {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1.5rem;
  position: relative;
  z-index: 1;
}

.connections-hive-group::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(to right, hsl(var(--dashboard-accent) / 0), hsl(var(--dashboard-accent) / 0.05), hsl(var(--dashboard-accent) / 0.1));
  opacity: 0;
  transition: opacity 0.5s;
  pointer-events: none;
  z-index: 0;
}

.connections-hive-card:hover .connections-hive-group::before {
  background: linear-gradient(to right, hsl(var(--dashboard-accent) / 0.05), hsl(var(--dashboard-accent) / 0.1), hsl(var(--dashboard-accent) / 0.2));
  opacity: 1;
}

.connections-hive-group::after {
  content: '';
  position: absolute;
  top: 0;
  right: 0;
  width: 8rem;
  height: 8rem;
  background-color: hsl(var(--dashboard-accent) / 0.1);
  border-radius: 9999px;
  filter: blur(3rem);
  opacity: 0;
  transition: opacity 0.5s;
  pointer-events: none;
  z-index: 0;
}

.connections-hive-card:hover .connections-hive-group::after {
  background-color: hsl(var(--dashboard-accent) / 0.2);
  opacity: 1;
}

.connections-hive-honeycomb {
  position: absolute;
  inset: 0;
  overflow: hidden;
  pointer-events: none;
  z-index: 0;
  opacity: 0;
  transition: opacity 0.5s;
}

.connections-hive-card:hover .connections-hive-honeycomb {
  opacity: 1;
}

.connections-hive-honeycomb svg {
  width: 100%;
  height: 100%;
  position: absolute;
  inset: 0;
}

.connections-hive-honeycomb svg path {
  stroke: hsl(var(--dashboard-accent) / 0.08);
}

.connections-hive-left {
  display: flex;
  align-items: center;
  gap: 1rem;
}

.connections-hive-icon {
  width: 3.5rem;
  height: 3.5rem;
  border-radius: 9999px;
  background-color: hsl(var(--dashboard-accent));
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 10px 15px -3px hsl(var(--a11y-shadow) / 0.1), 0 4px 6px -2px hsl(var(--a11y-shadow) / 0.05);
  transition: transform 0.3s;
  color: hsl(0, 0%, 0%);
  flex-shrink: 0;
}

.connections-hive-icon svg {
  width: 1.75rem;
  height: 1.75rem;
}

.connections-hive-card:hover .connections-hive-icon {
  transform: scale(1.1);
}

.connections-hive-text {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.connections-hive-title {
  font-size: 1.25rem;
  font-weight: 700;
  color: hsl(var(--dashboard-text));
  margin: 0 0 0.25rem 0;
  line-height: 1;
}

.connections-hive-subtitle {
  font-size: 0.875rem;
  margin: 0;
}

.connections-hive-right {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.connections-hive-cta {
  padding: 0.5rem 1rem;
  font-size: 0.875rem;
  font-weight: 600;
  color: hsl(var(--dashboard-accent));
  white-space: nowrap;
}

.connections-hive-arrow {
  width: 1.5rem;
  height: 1.5rem;
  color: hsl(var(--dashboard-accent));
  transition: transform 0.3s;
  flex-shrink: 0;
}

.connections-hive-card:hover .connections-hive-arrow {
  transform: translateX(0.5rem);
}

.connections-list {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.connections-platform-card {
  border-color: hsl(var(--dashboard-border) / 0.3);
  transition: all 0.3s;
  cursor: pointer;
  text-decoration: none;
  color: inherit;
  position: relative;
  overflow: hidden;
}

.connections-platform-card:hover {
  border-color: hsl(var(--dashboard-accent) / 0.6);
  box-shadow: 0 10px 15px -3px hsl(var(--a11y-shadow) / 0.1), 0 4px 6px -2px hsl(var(--a11y-shadow) / 0.05);
  transform: translateY(-0.125rem);
}

.connections-platform-honeycomb {
  position: absolute;
  inset: 0;
  overflow: hidden;
  pointer-events: none;
  z-index: 0;
  opacity: 0;
  transition: opacity 0.5s;
}

.connections-platform-card:hover .connections-platform-honeycomb {
  opacity: 1;
}

.connections-platform-honeycomb svg {
  width: 100%;
  height: 100%;
  position: absolute;
  inset: 0;
}

.connections-platform-honeycomb svg path {
  stroke: hsl(var(--dashboard-accent) / 0.12);
}

.connections-platform-honeycomb[data-platform="meta"] svg path,
.connections-platform-honeycomb[data-platform="facebook"] svg path {
  stroke: hsl(217 91% 60% / 0.12);
}

.connections-platform-honeycomb[data-platform="google_ads"] svg path {
  stroke: hsl(45 93% 47% / 0.12);
}

.connections-platform-honeycomb[data-platform="tiktok_ads"] svg path {
  stroke: hsl(0 0% 100% / 0.12);
}

.connections-platform-honeycomb[data-platform="pinterest"] svg path {
  stroke: hsl(0 84% 60% / 0.25);
}

.connections-platform-honeycomb[data-platform="x"] svg path {
  stroke: hsl(0 0% 63% / 0.12);
}

.connections-platform-content {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1.5rem;
  position: relative;
  z-index: 1;
}

.connections-platform-card > .card-content {
  padding: 0;
}

.connections-platform-left {
  display: flex;
  align-items: center;
  gap: 1rem;
  flex: 1;
  min-width: 0;
}

.connections-platform-logo {
  width: 2.5rem;
  height: 2.5rem;
  border-radius: calc(var(--radius) - 2px);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  transition: transform 0.3s;
  flex-shrink: 0;
}

.connections-platform-icon {
  width: 2rem;
  height: 2rem;
  object-fit: contain;
}

.connections-platform-card:hover .connections-platform-icon {
  transform: scale(1.1);
}

.connections-platform-name {
  font-size: 1.125rem;
  font-weight: 600;
  color: hsl(var(--dashboard-text));
  margin: 0;
  line-height: 1.2;
}

.connections-status-connected {
  padding: 0.5rem 1rem;
  font-size: 0.875rem;
  font-weight: 500;
  color: hsl(var(--dashboard-accent));
  white-space: nowrap;
}

.connections-status-coming-soon {
  padding: 0.5rem 1rem;
  font-size: 0.875rem;
  font-weight: 500;
}

.connections-platform-right {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  flex-shrink: 0;
}

.connections-connect-btn {
  height: auto;
  padding: 0.5rem 1rem;
  border-color: hsl(var(--dashboard-accent));
  color: hsl(var(--dashboard-text));
  background-color: transparent;
  transition: all 0.3s;
}

.connections-connect-btn:hover {
  background-color: hsl(var(--dashboard-accent));
  color: hsl(0, 0%, 0%);
  box-shadow: 0 10px 15px -3px hsl(var(--a11y-shadow) / 0.1), 0 4px 6px -2px hsl(var(--a11y-shadow) / 0.05), 0 0 20px -5px hsl(var(--dashboard-accent) / 0.3);
}

.connections-platform-arrow {
  width: 1.5rem;
  height: 1.5rem;
  color: hsl(var(--dashboard-accent));
  transition: transform 0.3s;
  flex-shrink: 0;
}

.connections-platform-card:hover .connections-platform-arrow {
  transform: translateX(0.25rem);
}

/* ============================================
   Sidebar
   ============================================ */

/* Sidebar open/closed layout
   - Default: open (content pushed right)
   - Persisted closed state: html.sidebar-closed
*/

html:not(.sidebar-closed) .page-container {
  margin-left: 18rem;
}

html:not(.sidebar-closed) .settings-page {
  margin-left: 18rem;
}

html.sidebar-closed .page-container,
html.sidebar-closed .settings-page {
  margin-left: 0;
}

.sidebar {
  position: fixed;
  top: 0;
  left: 0;
  height: 100vh;
  width: 18rem;
  background-color: hsl(var(--sidebar-background));
  border-right: 1px solid hsl(var(--sidebar-border));
  display: flex;
  flex-direction: column;
  z-index: 50;
  overflow-x: hidden;
  transform: translateX(0);
  opacity: 1;
  transition: transform 0.2s ease, opacity 0.2s ease;
  will-change: transform, opacity;
}

.page-container,
.settings-page {
  transition: margin-left 0.2s ease;
}

html.sidebar-closed .sidebar {
  transform: translateX(-100%);
  opacity: 0;
  pointer-events: none;
}

.sidebar-content {
  flex: 1;
  padding: 1.5rem;
  overflow-y: auto;
  overflow-x: hidden;
}

.sidebar-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  margin-bottom: 1rem;
}

.sidebar-logo-section {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.sidebar-logo-wrapper {
  width: 3rem;
  height: 3rem;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid hsl(var(--dashboard-accent));
  border-radius: 9999px;
}

.sidebar-logo {
  width: 100%;
  height: 100%;
  object-fit: contain;
  padding: 0.25rem;
}

.sidebar-title {
  color: hsl(var(--sidebar-foreground));
  font-weight: 700;
  font-size: 1.125rem;
  margin: 0;
}

.sidebar-close-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  border-radius: calc(var(--radius) - 2px);
  background-color: transparent;
  color: hsl(var(--sidebar-foreground));
  border: none;
  cursor: pointer;
  transition: all 0.2s;
  flex-shrink: 0;
}

.sidebar-close-btn:hover {
  background-color: hsl(var(--sidebar-accent));
}

.sidebar-separator {
  margin: 1rem 0;
  background-color: hsl(var(--sidebar-border));
}

.sidebar-user-info {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 1rem;
}

.sidebar-username {
  color: hsl(var(--sidebar-foreground));
  font-size: 0.75rem;
  font-weight: 500;
  margin: 0;
  line-height: 1.2;
}

.sidebar-company {
  color: hsl(var(--sidebar-foreground) / 0.6);
  font-size: 0.75rem;
  margin: 0;
  line-height: 1.2;
}

.sidebar-nav {
  margin-top: 1.5rem;
}

.sidebar-nav-label {
  color: hsl(var(--sidebar-foreground) / 0.6);
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin: 0 0 0.75rem 0;
}

.sidebar-nav-link {
  display: flex;
  align-items: center;
  width: 100%;
  padding: 0.5rem 1rem;
  color: hsl(var(--sidebar-foreground));
  text-decoration: none;
  border-radius: calc(var(--radius) - 2px);
  transition: all 0.2s;
  margin-bottom: 0.125rem;
}

.sidebar-nav-link:hover {
  transform: scale(1.05);
}

.sidebar-nav-link:hover .sidebar-nav-icon,
.sidebar-nav-link:hover span {
  color: hsl(var(--dashboard-accent));
}

.sidebar-nav-link-active .sidebar-nav-icon,
.sidebar-nav-link-active span {
  color: hsl(var(--dashboard-accent));
}

.sidebar-nav-icon {
  width: 1.25rem;
  height: 1.25rem;
  margin-right: 0.75rem;
  transition: color 0.2s;
  flex-shrink: 0;
}

.sidebar-nav-link span {
  transition: color 0.2s;
}

.sidebar-footer {
  padding: 1.5rem;
  margin-top: auto;
}

.sidebar-logout-btn {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  width: 100%;
  padding: 0.5rem 1rem;
  padding-left: 5rem;
  color: hsl(0 84% 60%);
  background-color: transparent;
  border: none;
  border-radius: calc(var(--radius) - 2px);
  text-decoration: none;
  transition: all 0.3s;
  cursor: pointer;
  font-size: 0.875rem;
}

.sidebar-logout-btn:hover {
  background-color: hsl(0 84% 60% / 0.1);
  color: hsl(0 84% 60%);
  box-shadow: 0 10px 15px -3px hsl(var(--a11y-shadow) / 0.1), 0 4px 6px -2px hsl(var(--a11y-shadow) / 0.05), 0 0 20px -5px hsl(0 84% 60% / 0.2);
}

.sidebar-logout-icon {
  width: 1.25rem;
  height: 1.25rem;
  margin-right: 0.75rem;
  transition: transform 0.3s;
  flex-shrink: 0;
}

.sidebar-logout-btn:hover .sidebar-logout-icon {
  transform: translateX(0.25rem);
}

.sidebar-footer-links {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0.5rem;
  color: hsl(var(--sidebar-foreground) / 0.6);
  font-size: 0.75rem;
}

.sidebar-footer-link {
  color: hsl(var(--sidebar-foreground) / 0.6);
  text-decoration: none;
  transition: all 0.2s;
}

.sidebar-footer-link:hover {
  color: hsl(var(--dashboard-accent));
  transform: scale(1.05);
}

.sidebar-footer-separator {
  color: hsl(var(--sidebar-foreground) / 0.6);
}

/* ============================================
   Meta Dashboard Styles
   ============================================ */

.meta-dashboard-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 2rem;
  flex-wrap: wrap;
  gap: 1rem;
  position: relative;
  z-index: 10010;
}

.meta-dashboard-header-left {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  flex-wrap: wrap;
}

.meta-back-btn {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  color: hsl(var(--dashboard-text-muted));
  text-decoration: none;
  font-size: 0.875rem;
  transition: color 0.2s;
}

.meta-back-btn:hover {
  color: hsl(var(--dashboard-text));
}

.meta-dashboard-title-group {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.meta-dashboard-logo {
  width: 2.5rem;
  height: 2.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.meta-logo-img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.meta-dashboard-title {
  font-size: 1.5rem;
  font-weight: 700;
  color: hsl(var(--dashboard-text));
  margin: 0;
}

.meta-dashboard-header-right {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  flex-wrap: nowrap;
  min-width: 0;
}



/* ============================================
   Module: dashboard-controls.css
   ============================================ */

/* Control Bar Container - Matches systemv structure exactly */
.meta-control-bar {
  display: flex;
  align-items: center;
  background-color: hsl(var(--dashboard-card) / 0.5);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  border: 1px solid hsl(var(--dashboard-border) / 0.3);
  border-radius: calc(var(--radius) - 2px);
  padding: 0.25rem;
  width: fit-content;
  position: relative;
  z-index: 10010;
}

.meta-control-bar-inner {
  display: flex;
  align-items: center;
}

/* Control Bar Buttons - Matches systemv button structure */
.meta-control-btn {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.5rem 1rem;
  border-radius: calc(var(--radius) - 4px);
  color: hsl(var(--dashboard-text));
  background: transparent;
  border: none;
  cursor: pointer;
  transition: all 0.2s ease;
  font-size: 0.875rem;
  font-weight: 500;
  text-decoration: none;
  position: relative;
  white-space: nowrap;
}

.meta-control-btn:hover {
  color: hsl(var(--dashboard-accent));
  background-color: transparent;
}

.meta-control-btn[data-state="open"] {
  color: hsl(var(--dashboard-accent));
}

/* Control Bar Icons - Matches systemv icon styling */
.meta-control-icon {
  width: 1rem;
  height: 1rem;
  color: hsl(var(--dashboard-accent));
  transition: all 0.2s ease;
  flex-shrink: 0;
}

.meta-control-btn:hover .meta-control-icon {
  color: hsl(var(--foreground));
}

.meta-control-btn[data-state="open"] .meta-control-icon {
  color: hsl(var(--foreground));
}

.meta-control-icon.animated-icon {
  transition: all 0.2s ease;
}

.meta-control-btn:hover .meta-control-icon.animated-icon {
  animation: iconBounce 0.5s ease-in-out;
}

/* Control Bar Chevron - Matches systemv chevron styling */
.meta-control-chevron {
  width: 0.875rem;
  height: 0.875rem;
  color: hsl(var(--dashboard-text-muted));
  transition: color 0.2s ease;
  flex-shrink: 0;
}

.meta-control-btn:hover .meta-control-chevron {
  color: hsl(var(--dashboard-accent));
}

/* Control Bar Label - Matches systemv label styling */
.meta-control-label {
  font-size: 0.875rem;
  font-weight: 500;
  max-width: 120px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* Control Bar Divider - Matches systemv divider */
.meta-control-divider {
  width: 1px;
  height: 1.5rem;
  background-color: hsl(var(--dashboard-border) / 0.5);
  flex-shrink: 0;
}

/* Icon Bounce Animation */
@keyframes iconBounce {
  0%, 100% {
    transform: translateY(0) rotate(0deg);
  }
  25% {
    transform: translateY(-2px) rotate(-5deg);
  }
  75% {
    transform: translateY(1px) rotate(3deg);
  }
}

/* Account Selector in Control Bar */
.meta-control-bar .account-selector-wrapper {
  position: relative;
  width: auto;
  min-width: auto;
  max-width: none;
}

.meta-control-bar .account-selector-wrapper button {
  width: auto;
  min-width: auto;
  max-width: none;
}

.meta-control-bar .account-selector-dropdown {
  top: calc(100% + 0.5rem);
  left: 0;
  right: auto;
}

/* Date Range Selector in Control Bar */
.meta-control-bar .date-range-selector-wrapper {
  position: relative;
}

.meta-control-bar .date-range-dropdown {
  top: calc(100% + 0.5rem);
  right: 0;
  left: auto;
}

/* Sync Button Animation */
.meta-control-btn-sync .meta-control-icon-sync {
  transition: transform 0.3s ease;
}

.meta-control-btn-sync:hover .meta-control-icon-sync {
  animation: iconBounce 0.5s ease-in-out;
}

.meta-control-btn-sync:active .meta-control-icon-sync,
.meta-control-btn-sync.syncing .meta-control-icon-sync {
  animation: spin 1s linear infinite;
}

@keyframes spin {
  from {
    transform: rotate(0deg);
  }
  to {
    transform: rotate(360deg);
  }
}

/* Meta Dashboard Header Buttons - Shared Styles */
.meta-dashboard-header-right .btn-outline,
.meta-dashboard-header-right .btn-default,
.meta-dashboard-header-right a.btn-outline,
.meta-dashboard-header-right a.btn-default,
.meta-header-btn.btn-outline,
.meta-header-btn.btn-default {
  height: 2.5rem;
  min-height: 2.5rem;
  max-height: 2.5rem;
  padding: 0.5rem 1rem;
  line-height: 1.25;
  font-size: 0.875rem;
  font-weight: 500;
  box-sizing: border-box;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
}

.meta-dashboard-header-right .btn-outline,
.meta-dashboard-header-right a.btn-outline,
.meta-header-btn.btn-outline {
  border-width: 1px;
}

.meta-dashboard-header-right .btn-default,
.meta-dashboard-header-right a.btn-default,
.meta-header-btn.btn-default {
  border-width: 0;
}

.meta-header-btn {
  width: auto;
  min-width: auto;
  border-color: hsl(var(--dashboard-border));
  background-color: transparent;
  color: hsl(var(--dashboard-text));
}

.meta-header-btn:hover,
.meta-dashboard-header-right .btn-default:hover,
.meta-dashboard-header-right a.btn-default:hover {
  border-color: hsl(var(--dashboard-accent) / 0.6);
  background-color: transparent;
  color: hsl(var(--dashboard-text));
  box-shadow: 0 10px 15px -3px hsl(var(--dashboard-accent) / 0.1), 0 4px 6px -2px hsl(var(--dashboard-accent) / 0.1);
  transition: all 0.3s;
}

/* Account Selector - Generic component for all dashboards */
.account-selector-wrapper {
  position: relative;
  display: flex;
  flex-shrink: 0;
  width: 200px;
  min-width: 200px;
  max-width: 200px;
}

.account-selector-wrapper button {
  width: 100%;
  overflow: hidden;
  flex-shrink: 0;
}

.account-selector-wrapper button span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  flex: 1;
  min-width: 0;
}

.account-selector-dropdown {
  position: absolute;
  top: calc(100% + 0.5rem);
  left: 0;
  right: auto;
  background-color: hsl(var(--dashboard-card));
  border: 1px solid hsl(var(--dashboard-border) / 0.3);
  border-radius: calc(var(--radius) - 2px);
  min-width: 20rem;
  max-width: 28rem;
  max-height: 20rem;
  overflow-y: auto;
  overflow-x: hidden;
  display: none;
  z-index: 100000;
  box-shadow: 0 4px 6px -1px hsl(var(--a11y-shadow) / 0.1), 0 2px 4px -1px hsl(var(--a11y-shadow) / 0.06);
  pointer-events: auto;
}

.account-selector-dropdown.show {
  display: block;
  opacity: 1;
  visibility: visible;
}

/* Fallback: allow dropdown to open on focus (prevents "click does nothing" edge cases) */
.account-selector-wrapper:focus-within .account-selector-dropdown {
  display: block;
}

.account-selector-dropdown-content {
  padding: 0.5rem;
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.account-selector-dropdown-item {
  padding: 0.625rem 0.75rem;
  cursor: pointer;
  border-radius: calc(var(--radius) - 4px);
  transition: all 0.2s;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.25rem;
  pointer-events: auto;
  position: relative;
  z-index: 1;
  width: 100%;
  box-sizing: border-box;
}

.account-selector-dropdown-item:hover {
  background-color: hsl(var(--dashboard-accent) / 0.1);
}

.account-selector-dropdown-item.selected {
  background-color: hsl(var(--dashboard-accent) / 0.15);
  border: 1px solid hsl(var(--dashboard-accent) / 0.3);
}

.account-selector-dropdown-item-name {
  font-size: 0.875rem;
  font-weight: 500;
  color: hsl(var(--dashboard-text));
  line-height: 1.25;
}

.account-selector-dropdown-item.selected .account-selector-dropdown-item-name {
  color: hsl(var(--dashboard-accent));
}

.account-selector-dropdown-item-id {
  font-size: 0.75rem;
  color: hsl(var(--dashboard-text-muted));
  line-height: 1.25;
}

/* Date Range Selector - Generic component for all dashboards */
.date-range-selector-wrapper {
  position: relative;
  display: inline-block;
}

/* Date Range Popover - Matches systemv structure */
.date-range-popover {
  position: absolute;
  top: calc(100% + 0.5rem);
  right: 0;
  left: auto;
  z-index: 100002;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-0.5rem);
  transition: opacity 0.2s ease, visibility 0.2s ease, transform 0.2s ease;
  pointer-events: none;
}

.date-range-popover.date-range-popover-open {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  pointer-events: auto;
}

.date-range-popover-content {
  background-color: hsl(var(--dashboard-card));
  border: 1px solid hsl(var(--dashboard-border));
  border-radius: calc(var(--radius) - 2px);
  box-shadow: 0 10px 15px -3px hsl(var(--a11y-shadow) / 0.1), 0 4px 6px -2px hsl(var(--a11y-shadow) / 0.05);
  width: auto;
  padding: 0;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  opacity: 1;
  position: relative;
  isolation: isolate;
  overflow: hidden;
  background-image: none;
  mix-blend-mode: normal;
  will-change: auto;
}

.date-range-popover-content * {
  mix-blend-mode: normal;
}

.date-range-popover-content,
.date-range-popover-content * {
  background-color: inherit;
  opacity: 1;
}

.date-range-popover-content::before {
  content: '';
  position: absolute;
  inset: 0;
  background-color: hsl(var(--dashboard-card));
  z-index: -1;
  border-radius: calc(var(--radius) - 2px);
  pointer-events: none;
  opacity: 1;
  mix-blend-mode: normal;
  will-change: auto;
}

.date-range-popover-inner {
  display: flex;
  position: relative;
  z-index: 1;
  background-color: hsl(var(--dashboard-card));
  mix-blend-mode: normal;
  opacity: 1;
  background-image: none;
}

/* Presets Sidebar - Left */
.date-range-presets-sidebar {
  width: 12rem;
  border-right: 1px solid hsl(var(--dashboard-border) / 0.3);
  padding: 0.5rem 0;
  background-color: hsl(var(--dashboard-card));
  position: relative;
  z-index: 2;
  flex-shrink: 0;
  background-image: none;
  opacity: 1;
  mix-blend-mode: normal;
}

.date-range-presets-header {
  padding: 0 0.75rem 0.5rem;
  margin-bottom: 0.25rem;
  border-bottom: 1px solid hsl(var(--dashboard-border) / 0.3);
}

.date-range-presets-title {
  font-size: 0.75rem;
  font-weight: 500;
  color: hsl(var(--dashboard-text-muted));
  text-transform: uppercase;
  letter-spacing: 0.05em;
  position: relative;
  z-index: 1;
}

.date-range-presets-list {
  padding: 0 0.25rem;
  display: flex;
  flex-direction: column;
  gap: 0.125rem;
  overflow-y: auto;
  max-height: 400px;
  position: relative;
  z-index: 1;
}

.date-range-preset-btn {
  width: 100%;
  text-align: left;
  padding: 0.375rem 0.75rem;
  font-size: 0.875rem;
  border-radius: calc(var(--radius) - 4px);
  transition: all 0.2s ease;
  background: transparent;
  border: none;
  color: hsl(var(--dashboard-text));
  cursor: pointer;
  position: relative;
  white-space: nowrap;
  z-index: 1;
}

.date-range-preset-btn:hover {
  color: hsl(var(--dashboard-accent));
  background-color: transparent;
}

.date-range-preset-btn-selected {
  color: hsl(var(--dashboard-accent));
  font-weight: 500;
  background-color: transparent;
}

/* Calendar Section - Right */
.date-range-calendar-section {
  padding: 1rem;
  min-width: 20rem;
  background-color: hsl(var(--dashboard-card));
  position: relative;
  z-index: 2;
  flex: 1;
  background-image: none;
  opacity: 1;
  mix-blend-mode: normal;
}

.date-range-display {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 0.75rem;
  padding: 0.5rem;
  background-color: hsl(var(--dashboard-bg) / 0.5);
  border-radius: calc(var(--radius) - 2px);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  position: relative;
  z-index: 1;
}

.date-range-display-item {
  flex: 1;
  min-width: 0;
  position: relative;
  z-index: 1;
}

.date-range-display-item-right {
  text-align: right;
}

.date-range-display-label {
  font-size: 0.625rem;
  color: hsl(var(--dashboard-text-muted));
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-bottom: 0.125rem;
  line-height: 1.2;
}

.date-range-display-value {
  font-size: 0.875rem;
  font-weight: 500;
  color: hsl(var(--dashboard-text));
  line-height: 1.2;
  word-break: break-word;
}

.date-range-arrow {
  width: 1rem;
  height: 1rem;
  color: hsl(var(--dashboard-text-muted));
  flex-shrink: 0;
  position: relative;
  z-index: 1;
}

.date-range-calendar-container {
  min-height: 200px;
}

.date-range-preset-message {
  padding: 1.5rem 1rem;
  text-align: center;
  background-color: hsl(var(--dashboard-bg) / 0.3);
  border-radius: calc(var(--radius) - 2px);
  border: 1px solid hsl(var(--dashboard-border) / 0.3);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  position: relative;
  z-index: 1;
}

.date-range-preset-message-text {
  font-size: 0.875rem;
  color: hsl(var(--dashboard-text-muted));
  margin-bottom: 0.25rem;
  line-height: 1.4;
}

.date-range-preset-message-preset {
  font-weight: 500;
  color: hsl(var(--dashboard-text));
}

.date-range-preset-message-hint {
  font-size: 0.75rem;
  color: hsl(var(--dashboard-text-muted));
  line-height: 1.4;
}

/* Compare Section */
.date-range-compare-section {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 1rem;
  padding-top: 1rem;
  border-top: 1px solid hsl(var(--dashboard-border) / 0.3);
  width: 100%;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.date-range-compare-toggle-wrapper {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  flex: 1;
  min-width: 0;
}

.date-range-compare-toggle {
  position: relative;
  display: inline-flex;
  height: 1.75rem;
  width: 3.5rem;
  flex-shrink: 0;
  cursor: pointer;
  align-items: center;
  border-radius: 9999px;
  transition: all 0.3s ease;
  background-color: hsl(var(--dashboard-border) / 0.4);
  border: 2px solid hsl(var(--dashboard-border) / 0.6);
  outline: none;
}

.date-range-compare-toggle:focus-visible {
  outline: 2px solid hsl(var(--dashboard-accent));
  outline-offset: 2px;
}

.date-range-compare-toggle-active {
  background-color: hsl(var(--dashboard-accent));
  border-color: hsl(var(--dashboard-accent));
}

.date-range-compare-toggle-on,
.date-range-compare-toggle-off {
  position: absolute;
  font-size: 0.5625rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  transition: opacity 0.2s ease;
  pointer-events: none;
}

.date-range-compare-toggle-on {
  left: 0.375rem;
  opacity: 0;
  color: hsl(var(--dashboard-bg));
}

.date-range-compare-toggle-off {
  right: 0.375rem;
  opacity: 1;
  color: hsl(var(--dashboard-text-muted));
}

.date-range-compare-toggle-active .date-range-compare-toggle-on {
  opacity: 1;
}

.date-range-compare-toggle-active .date-range-compare-toggle-off {
  opacity: 0;
}

.date-range-compare-toggle-thumb {
  pointer-events: none;
  position: relative;
  display: flex;
  height: 1.25rem;
  width: 1.25rem;
  align-items: center;
  justify-content: center;
  border-radius: 9999px;
  box-shadow: 0 1px 2px 0 hsl(var(--a11y-shadow) / 0.1);
  transition: all 0.3s ease;
  transform: translateX(0.25rem);
  background-color: hsl(var(--dashboard-text-muted));
}

.date-range-compare-toggle-active .date-range-compare-toggle-thumb {
  transform: translateX(1.75rem);
  background-color: hsl(var(--dashboard-bg));
}

.date-range-compare-toggle-thumb svg {
  width: 0.75rem;
  height: 0.75rem;
  color: hsl(var(--dashboard-bg));
  transition: color 0.2s ease;
}

.date-range-compare-toggle-active .date-range-compare-toggle-thumb svg {
  color: hsl(var(--dashboard-accent));
}

.date-range-compare-label {
  font-size: 0.875rem;
  font-weight: 500;
  color: hsl(var(--dashboard-text));
  cursor: pointer;
  transition: color 0.2s ease;
  user-select: none;
  white-space: nowrap;
}

.date-range-compare-label-active {
  color: hsl(var(--dashboard-accent));
}

/* Apply Button */
.date-range-apply-btn {
  width: 100%;
  margin-top: 1rem;
  padding: 0.625rem;
  background-color: hsl(var(--dashboard-card));
  color: hsl(var(--dashboard-text));
  border: 2px solid hsl(var(--dashboard-accent));
  border-radius: calc(var(--radius) - 2px);
  font-weight: 500;
  font-size: 0.875rem;
  cursor: pointer;
  transition: all 0.2s ease;
  position: relative;
  z-index: 1;
}

.date-range-apply-btn:hover {
  background-color: hsl(var(--dashboard-accent));
  color: hsl(var(--dashboard-bg));
}

/* Calendar Component - Systemv Style */
.date-range-calendar-rdp {
  padding: 0.75rem;
  position: relative;
  z-index: 1;
  background-color: transparent;
  pointer-events: auto;
  border-radius: calc(var(--radius) - 2px);
  border: 1px solid hsl(var(--dashboard-border) / 0.3);
}

.date-range-calendar-caption {
  display: flex;
  justify-content: center;
  padding-top: 0.25rem;
  position: relative;
  align-items: center;
  margin-bottom: 0;
}

.date-range-calendar-caption-label {
  font-size: 0.875rem;
  font-weight: 500;
  color: hsl(var(--dashboard-text));
  text-align: center;
  line-height: 1.5;
}

.date-range-calendar-caption-nav {
  position: absolute;
  display: flex;
  align-items: center;
  gap: 0.25rem;
  width: 100%;
  justify-content: space-between;
  pointer-events: none;
}

.date-range-calendar-nav {
  width: 1.75rem;
  height: 1.75rem;
  padding: 0;
  background: transparent;
  border: 0;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  color: hsl(var(--dashboard-accent));
  transition: all 0.2s ease;
  border-radius: calc(var(--radius) - 4px);
  pointer-events: auto;
  opacity: 1;
}

.date-range-calendar-nav:hover {
  background: transparent;
  color: hsl(var(--dashboard-accent));
}

.date-range-calendar-nav-icon {
  width: 1rem;
  height: 1rem;
  transition: color 0.2s ease;
  color: hsl(var(--dashboard-accent));
}

.date-range-calendar-nav-prev {
  position: absolute;
  left: 0.25rem;
}

.date-range-calendar-nav-next {
  position: absolute;
  right: 0.25rem;
}

.date-range-calendar-table {
  width: 100%;
  border-collapse: collapse;
  margin-top: 0.25rem;
}

.date-range-calendar-head {
  display: table-header-group;
}

.date-range-calendar-head-row {
  display: flex;
  width: 100%;
}

.date-range-calendar-weekday {
  width: 2.25rem;
  height: 2.25rem;
  font-size: 0.8rem;
  font-weight: normal;
  color: hsl(var(--dashboard-text-muted));
  text-align: center;
  padding: 0;
  border-radius: calc(var(--radius) - 4px);
  line-height: 1.5;
}

.date-range-calendar-body {
  display: table-row-group;
}

.date-range-calendar-row {
  display: flex;
  width: 100%;
  margin-top: 0.5rem;
}

.date-range-calendar-day-cell {
  height: 2.25rem;
  width: 2.25rem;
  text-align: center;
  font-size: 0.875rem;
  padding: 0;
  position: relative;
}

.date-range-calendar-day-cell:has(.date-range-calendar-day-range-end) {
  border-top-right-radius: calc(var(--radius) - 4px);
  border-bottom-right-radius: calc(var(--radius) - 4px);
}

.date-range-calendar-day-cell:has(.date-range-calendar-day-outside) {
  background-color: hsl(var(--dashboard-accent) / 0.5);
}

.date-range-calendar-day-cell:has(.date-range-calendar-day-selected) {
  background-color: hsl(var(--dashboard-accent));
}

.date-range-calendar-day-cell:has(.date-range-calendar-day-selected):first-child {
  border-top-left-radius: calc(var(--radius) - 4px);
  border-bottom-left-radius: calc(var(--radius) - 4px);
}

.date-range-calendar-day-cell:has(.date-range-calendar-day-selected):last-child {
  border-top-right-radius: calc(var(--radius) - 4px);
  border-bottom-right-radius: calc(var(--radius) - 4px);
}

.date-range-calendar-day-cell-range {
  background-color: hsl(var(--dashboard-accent));
}

.date-range-calendar-day-cell-start {
  border-top-left-radius: calc(var(--radius) - 4px);
  border-bottom-left-radius: calc(var(--radius) - 4px);
}

.date-range-calendar-day-cell-end {
  border-top-right-radius: calc(var(--radius) - 4px);
  border-bottom-right-radius: calc(var(--radius) - 4px);
}

.date-range-calendar-day-btn {
  width: 100%;
  height: 100%;
  padding: 0;
  font-size: 0.875rem;
  border-radius: calc(var(--radius) - 4px);
  border: none;
  background: transparent;
  color: hsl(var(--dashboard-text));
  cursor: pointer;
  transition: all 0.2s ease;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  position: relative;
  z-index: 1;
  line-height: 1;
  font-weight: normal;
  white-space: nowrap;
}

.date-range-calendar-day-btn:hover:not(:disabled) {
  background-color: hsl(var(--dashboard-accent) / 0.3);
  color: hsl(var(--dashboard-text));
}

.date-range-calendar-day-btn:focus-visible {
  outline: 2px solid hsl(var(--dashboard-accent) / 0.5);
  outline-offset: 2px;
}

.date-range-calendar-day-btn:disabled {
  pointer-events: none;
  opacity: 0.5;
}

.date-range-calendar-day-outside {
  color: hsl(var(--dashboard-text-muted));
  opacity: 0.5;
}

.date-range-calendar-day-outside[aria-selected] {
  background-color: hsl(var(--dashboard-accent) / 0.5);
  color: hsl(var(--dashboard-text-muted));
  opacity: 0.3;
}

.date-range-calendar-day-disabled {
  color: hsl(var(--dashboard-text-muted));
  opacity: 0.5;
}

.date-range-calendar-day-selected {
  background-color: hsl(var(--dashboard-accent));
  color: hsl(var(--dashboard-bg));
  font-weight: normal;
}

.date-range-calendar-day-selected:hover {
  background-color: hsl(var(--dashboard-accent));
  color: hsl(var(--dashboard-bg));
}

.date-range-calendar-day-range-start {
  background-color: hsl(var(--dashboard-accent));
  color: hsl(var(--dashboard-bg));
}

.date-range-calendar-day-range-end {
  background-color: hsl(var(--dashboard-accent) / 0.19);
  color: hsl(var(--dashboard-text));
  font-weight: 700;
}

.date-range-calendar-day-in-range {
  background-color: hsl(var(--dashboard-accent));
  color: hsl(var(--dashboard-bg));
}

.date-range-dropdown {
  position: absolute;
  top: calc(100% + 0.5rem);
  right: 0;
  min-width: 180px;
  max-width: 400px;
  width: max-content;
  background-color: hsl(var(--dashboard-card));
  border: 1px solid hsl(var(--dashboard-border) / 0.3);
  border-radius: calc(var(--radius) - 2px);
  box-shadow: 0 4px 12px hsl(var(--dashboard-border) / 0.2);
  z-index: 10001;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-0.5rem);
  transition: opacity 0.2s ease, visibility 0.2s ease, transform 0.2s ease;
  overflow: visible;
  box-sizing: border-box;
  pointer-events: none;
}

.date-range-dropdown.show {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  pointer-events: auto;
}

.date-range-dropdown-content {
  padding: 0.5rem;
  max-height: 300px;
  overflow-y: auto;
  overflow-x: hidden;
}

.date-range-dropdown-item {
  padding: 0.625rem 0.75rem;
  border-radius: calc(var(--radius) - 4px);
  cursor: pointer;
  transition: background-color 0.15s ease;
  display: flex;
  align-items: center;
  justify-content: space-between;
  pointer-events: auto;
  position: relative;
  z-index: 1;
}

.date-range-dropdown-item:hover {
  background-color: hsl(var(--dashboard-accent) / 0.1);
}

.date-range-dropdown-item.selected {
  background-color: hsl(var(--dashboard-accent) / 0.15);
  font-weight: 500;
}

.date-range-dropdown-item-name {
  font-size: 0.875rem;
  color: hsl(var(--dashboard-text));
}

/* Custom Date Picker Styles - Generic component */
.custom-date-picker {
  padding: 1rem;
  min-width: 320px;
  max-width: 100%;
  box-sizing: border-box;
}

.custom-date-picker-header {
  margin-bottom: 1rem;
}

.custom-date-picker-title {
  font-size: 0.875rem;
  font-weight: 600;
  color: hsl(var(--dashboard-text));
  display: block;
  margin-bottom: 0.25rem;
}

.custom-date-picker-hint {
  font-size: 0.75rem;
  color: hsl(var(--dashboard-text-muted));
  display: block;
  font-weight: normal;
}

.custom-date-picker-body {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  margin-bottom: 1rem;
}

.custom-date-input-group {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.custom-date-label {
  font-size: 0.75rem;
  font-weight: 500;
  color: hsl(var(--dashboard-text-muted));
}

.custom-date-input {
  width: 100%;
  padding: 0.5rem 0.75rem;
  font-size: 0.875rem;
}

.custom-date-picker-footer {
  display: flex;
  gap: 0.5rem;
  justify-content: flex-end;
  padding-top: 0.75rem;
  border-top: 1px solid hsl(var(--dashboard-border) / 0.3);
}

.custom-date-cancel,
.custom-date-apply {
  padding: 0.5rem 1rem;
  font-size: 0.875rem;
}

/* Calendar Picker Styles - Generic component */
.calendar-container {
  display: block; /* Always visible when inside modal */
}

.calendar-modal {
  position: fixed;
  z-index: 10002;
  background-color: hsl(var(--dashboard-card));
  border: 1px solid hsl(var(--dashboard-border) / 0.3);
  border-radius: calc(var(--radius) - 2px);
  box-shadow: 0 8px 24px hsl(var(--dashboard-border) / 0.2);
  padding: 1rem;
  min-width: 280px;
  max-width: 320px;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-0.5rem) scale(0.95);
  transition: opacity 0.2s ease, visibility 0.2s ease, transform 0.2s ease;
  pointer-events: none;
}

.calendar-modal.show {
  opacity: 1;
  visibility: visible;
  transform: translateY(0) scale(1);
  pointer-events: auto;
}

.calendar-toggle-btn {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.5rem 0.75rem;
  font-size: 0.875rem;
  color: hsl(var(--dashboard-text));
  background-color: transparent;
  border: 1px solid hsl(var(--dashboard-border) / 0.3);
  border-radius: calc(var(--radius) - 4px);
  cursor: pointer;
  transition: all 0.15s ease;
  margin-top: 0.5rem;
  width: 100%;
  justify-content: center;
}

.calendar-toggle-btn:hover {
  background-color: hsl(var(--dashboard-accent) / 0.1);
  border-color: hsl(var(--dashboard-accent) / 0.3);
}

.calendar-toggle-btn svg {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
}

.calendar {
  width: 100%;
  background-color: hsl(var(--dashboard-card));
  border-radius: calc(var(--radius) - 2px);
}

.calendar-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.75rem;
  border-bottom: 1px solid hsl(var(--dashboard-border) / 0.3);
}

.calendar-month-year {
  font-size: 0.875rem;
  font-weight: 600;
  color: hsl(var(--dashboard-text));
}

.calendar-nav-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  border: none;
  background-color: transparent;
  color: hsl(var(--dashboard-text));
  cursor: pointer;
  border-radius: calc(var(--radius) - 4px);
  transition: background-color 0.15s ease;
  padding: 0;
}

.calendar-nav-btn:hover {
  background-color: hsl(var(--dashboard-accent) / 0.1);
}

.calendar-nav-btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.calendar-weekdays {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 0.25rem;
  padding: 0.5rem;
  border-bottom: 1px solid hsl(var(--dashboard-border) / 0.3);
}

.calendar-weekday {
  text-align: center;
  font-size: 0.75rem;
  font-weight: 500;
  color: hsl(var(--dashboard-text-muted));
  padding: 0.5rem 0;
}

.calendar-days {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 0.25rem;
  padding: 0.5rem;
}

.calendar-day {
  aspect-ratio: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  border: none;
  background-color: transparent;
  color: hsl(var(--dashboard-text));
  font-size: 0.875rem;
  cursor: pointer;
  border-radius: calc(var(--radius) - 4px);
  transition: all 0.15s ease;
  padding: 0;
  min-height: 2.5rem;
}

.calendar-day:hover:not(.calendar-day-disabled):not(.calendar-day-start):not(.calendar-day-end) {
  background-color: hsl(var(--dashboard-accent) / 0.1);
}

.calendar-day-empty {
  cursor: default;
  pointer-events: none;
}

.calendar-day-disabled {
  opacity: 0.3;
  cursor: not-allowed;
  pointer-events: none;
}

.calendar-day-today {
  font-weight: 600;
  border: 1px solid hsl(var(--dashboard-border) / 0.5);
}

.calendar-day-start,
.calendar-day-end {
  background-color: hsl(var(--dashboard-accent));
  color: hsl(var(--dashboard-accent-foreground));
  font-weight: 600;
}

.calendar-day-start:hover,
.calendar-day-end:hover {
  background-color: hsl(var(--dashboard-accent) / 0.9);
}

.calendar-day-in-range {
  background-color: hsl(var(--dashboard-accent) / 0.2);
  color: hsl(var(--dashboard-text));
}

.calendar-day-in-range:hover {
  background-color: hsl(var(--dashboard-accent) / 0.3);
}

/* Date Range Error Message */
.date-range-error {
  position: fixed;
  top: 1rem;
  right: 1rem;
  background: hsl(var(--destructive));
  color: hsl(var(--destructive-foreground));
  padding: 1rem;
  border-radius: calc(var(--radius) - 2px);
  box-shadow: 0 4px 12px hsl(var(--destructive) / 0.3);
  z-index: 10000;
  max-width: 400px;
  font-size: 0.875rem;
  pointer-events: auto;
}

.meta-kpi-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 1rem;
  margin-bottom: 2rem;
}

.meta-kpi-card {
  border: 1px solid hsl(var(--dashboard-border) / 0.3);
  padding: 1rem;
  transition: all 0.3s;
}

.meta-kpi-card:hover {
  border-color: hsl(var(--dashboard-accent) / 0.6);
  box-shadow: 0 10px 15px -3px hsl(var(--dashboard-accent) / 0.1), 0 4px 6px -2px hsl(var(--dashboard-accent) / 0.1);
}

.meta-kpi-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 0.5rem;
}

.meta-kpi-icon {
  color: hsl(var(--dashboard-accent));
  flex-shrink: 0;
}

.meta-kpi-change {
  font-size: 0.75rem;
  font-weight: 600;
}

.meta-kpi-positive {
  color: hsl(142 71% 45%);
}

.meta-kpi-negative {
  color: hsl(0 84% 60%);
}

.meta-kpi-value {
  font-size: 1.5rem;
  font-weight: 700;
  color: hsl(var(--dashboard-text));
  margin: 0 0 0.25rem 0;
  line-height: 1;
}

.meta-kpi-label {
  font-size: 0.875rem;
  color: hsl(var(--dashboard-text-muted));
  margin: 0;
  display: flex;
  align-items: center;
  gap: 0.375rem;
}

.meta-kpi-label-text {
  flex: 1;
}




/* ============================================
   Module: kpi-selector.css
   ============================================ */

/* KPI Selector Modal - Generic styles for all platforms */
.kpi-modal,
.meta-kpi-modal {
  position: fixed;
  inset: 0;
  z-index: 1000;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 1rem;
}

.kpi-modal[aria-hidden="false"],
.meta-kpi-modal[aria-hidden="false"] {
  display: flex;
}

.kpi-modal-overlay,
.meta-kpi-modal-overlay {
  position: absolute;
  inset: 0;
  background-color: hsl(var(--background) / 0.8);
  backdrop-filter: blur(4px);
}

.kpi-modal-content,
.meta-kpi-modal-content {
  position: relative;
  background-color: hsl(var(--dashboard-card));
  border: 2px solid hsl(var(--dashboard-accent) / 0.5);
  border-radius: var(--radius);
  max-width: 48rem;
  width: 100%;
  max-height: 90vh;
  display: flex;
  flex-direction: column;
  box-shadow: 0 20px 25px -5px hsl(var(--dashboard-accent) / 0.2), 0 10px 10px -5px hsl(var(--dashboard-accent) / 0.2);
  overflow: hidden;
}

.kpi-modal-header,
.meta-kpi-modal-header {
  position: relative;
  background: linear-gradient(to right, hsl(var(--dashboard-accent) / 0.2), hsl(var(--dashboard-accent) / 0.1), transparent);
  padding: 1.5rem;
  border-bottom: 1px solid hsl(var(--dashboard-accent) / 0.3);
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
}

.kpi-modal-header::before,
.meta-kpi-modal-header::before {
  content: '';
  position: absolute;
  top: 0;
  right: 0;
  width: 8rem;
  height: 8rem;
  background-color: hsl(var(--dashboard-accent) / 0.05);
  border-radius: 50%;
  filter: blur(3rem);
  pointer-events: none;
  z-index: 0;
}

.kpi-modal-header-content {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  flex: 1;
}

.kpi-modal-icon-wrapper {
  padding: 0.5rem;
  background-color: hsl(var(--dashboard-accent));
  border-radius: calc(var(--radius) - 2px);
  display: flex;
  align-items: center;
  justify-content: center;
}

.kpi-modal-icon-wrapper svg {
  width: 1.25rem;
  height: 1.25rem;
  color: hsl(var(--dashboard-bg));
}

.kpi-modal-title {
  font-size: 1.5rem;
  font-weight: 700;
  color: hsl(var(--dashboard-text));
  margin: 0;
}

.kpi-modal-subtitle {
  font-size: 0.875rem;
  color: hsl(var(--dashboard-text-muted));
  margin: 0.5rem 0 0 0;
}

.kpi-modal-count,
.kpi-modal-selected {
  color: hsl(var(--dashboard-accent));
  font-weight: 600;
}

.kpi-modal-close {
  position: relative;
  z-index: 1;
  background: none;
  border: none;
  padding: 0.5rem;
  cursor: pointer;
  color: hsl(var(--dashboard-text-muted));
  transition: all 0.2s;
  border-radius: calc(var(--radius) - 2px);
  display: flex;
  align-items: center;
  justify-content: center;
}

.kpi-modal-close:hover {
  background-color: hsl(var(--dashboard-accent) / 0.1);
  color: hsl(var(--dashboard-accent));
}

.kpi-modal-close svg {
  width: 1.25rem;
  height: 1.25rem;
}

.kpi-modal-body,
.meta-kpi-modal-body {
  display: flex;
  height: 28.125rem;
  overflow: hidden;
}

.kpi-modal-sidebar {
  width: 14rem;
  background-color: hsl(var(--dashboard-bg) / 0.5);
  border-right: 1px solid hsl(var(--dashboard-border) / 0.3);
  padding: 0.75rem;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  overflow-y: auto;
}

.kpi-modal-category-btn {
  position: relative;
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.75rem;
  border-radius: calc(var(--radius) - 2px);
  text-align: left;
  transition: all 0.2s;
  border: 1px solid transparent;
  background: none;
  cursor: pointer;
  color: hsl(var(--dashboard-text));
  font-size: 0.875rem;
  font-weight: 500;
}

.kpi-modal-category-btn:hover {
  background-color: hsl(var(--dashboard-accent) / 0.1);
  border-color: hsl(var(--dashboard-accent) / 0.3);
}

.kpi-modal-category-btn.active {
  background-color: hsl(var(--dashboard-accent));
  color: hsl(var(--dashboard-bg));
  box-shadow: 0 10px 15px -3px hsl(var(--dashboard-accent) / 0.3), 0 4px 6px -2px hsl(var(--dashboard-accent) / 0.3);
}

.kpi-modal-category-btn.active .kpi-modal-category-icon {
  background-color: hsl(var(--dashboard-bg) / 0.2);
}

.kpi-modal-category-icon {
  padding: 0.375rem;
  border-radius: calc(var(--radius) - 4px);
  background-color: hsl(var(--dashboard-accent) / 0.1);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.kpi-modal-category-icon svg {
  width: 1.25rem;
  height: 1.25rem;
}

.kpi-modal-category-name {
  flex: 1;
}

.kpi-modal-category-count {
  font-size: 0.75rem;
  font-weight: 700;
  padding: 0.125rem 0.5rem;
  border-radius: 9999px;
}

.kpi-modal-category-btn.active .kpi-modal-category-count {
  background-color: hsl(var(--dashboard-bg) / 0.3);
  color: hsl(var(--dashboard-bg));
}

.kpi-modal-category-btn:not(.active) .kpi-modal-category-count {
  background-color: hsl(var(--dashboard-accent) / 0.2);
  color: hsl(var(--dashboard-accent));
}

.kpi-modal-main {
  flex: 1;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

.kpi-modal-category-header {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 1rem;
  border-bottom: 1px solid hsl(var(--dashboard-border) / 0.3);
}

.kpi-modal-category-header-icon {
  padding: 0.375rem;
  border-radius: calc(var(--radius) - 4px);
  background-color: hsl(var(--dashboard-accent) / 0.1);
  display: flex;
  align-items: center;
  justify-content: center;
}

.kpi-modal-category-header-icon svg {
  width: 1.25rem;
  height: 1.25rem;
  color: hsl(var(--dashboard-accent));
}

.kpi-modal-category-header-title {
  font-size: 1.125rem;
  font-weight: 600;
  color: hsl(var(--dashboard-text));
  margin: 0;
}

.kpi-modal-scroll {
  flex: 1;
  overflow-y: auto;
  padding: 1rem;
}

.kpi-modal-grid,
.meta-kpi-modal-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.75rem;
}

.kpi-modal-option {
  position: relative;
  padding: 1rem;
  border-radius: calc(var(--radius) - 2px);
  text-align: left;
  transition: all 0.2s;
  border: 2px solid;
  cursor: pointer;
  background-color: hsl(var(--dashboard-bg) / 0.3);
}

.kpi-modal-option:hover {
  border-color: hsl(var(--dashboard-accent) / 0.5);
  background-color: hsl(var(--dashboard-bg) / 0.5);
}

.kpi-modal-option.selected {
  background-color: hsl(var(--dashboard-accent) / 0.15);
  border-color: hsl(var(--dashboard-accent));
  box-shadow: 0 4px 6px -1px hsl(var(--dashboard-accent) / 0.2), 0 2px 4px -1px hsl(var(--dashboard-accent) / 0.2);
}

.kpi-modal-option.selected::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: calc(var(--radius) - 2px);
  background-color: hsl(var(--dashboard-accent) / 0.05);
  pointer-events: none;
}

.kpi-modal-option.disabled {
  opacity: 0.4;
  cursor: not-allowed;
}

.kpi-modal-option-label {
  font-size: 0.875rem;
  font-weight: 500;
  line-height: 1.4;
  color: hsl(var(--dashboard-text));
  margin: 0;
  padding-right: 1.5rem;
}

.kpi-modal-option.selected .kpi-modal-option-label {
  color: hsl(var(--dashboard-accent));
}

.kpi-modal-option-check {
  position: absolute;
  top: 1rem;
  right: 1rem;
  width: 1.25rem;
  height: 1.25rem;
  border-radius: 50%;
  border: 2px solid;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: all 0.2s;
}

.kpi-modal-option:not(.selected) .kpi-modal-option-check {
  border-color: hsl(var(--dashboard-border) / 0.5);
}

.kpi-modal-option.selected .kpi-modal-option-check {
  background-color: hsl(var(--dashboard-accent));
  border-color: hsl(var(--dashboard-accent));
}

.kpi-modal-option-check svg {
  width: 0.75rem;
  height: 0.75rem;
  color: hsl(var(--dashboard-bg));
  display: none;
}

.kpi-modal-option.selected .kpi-modal-option-check svg {
  display: block;
}



/* ============================================
   Module: charts.css
   ============================================ */

/* Strategic Charts specific styles */
.kpi-modal-option-name {
  font-size: 0.875rem;
  font-weight: 500;
  line-height: 1.25;
  color: hsl(var(--dashboard-text));
  flex: 1;
}

.kpi-modal-option-checkbox {
  width: 1.25rem;
  height: 1.25rem;
  border-radius: 50%;
  border: 2px solid;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: all 0.2s;
  border-color: hsl(var(--dashboard-border) / 0.5);
}

.kpi-modal-option.selected .kpi-modal-option-checkbox {
  background-color: hsl(var(--dashboard-accent));
  border-color: hsl(var(--dashboard-accent));
}

.kpi-modal-option-checkbox svg {
  width: 0.75rem;
  height: 0.75rem;
  color: hsl(var(--dashboard-bg));
  display: none;
}

.kpi-modal-option.selected .kpi-modal-option-checkbox svg {
  display: block;
}

.kpi-modal-footer,
.meta-kpi-modal-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  padding: 1rem;
  border-top: 1px solid hsl(var(--dashboard-border) / 0.3);
  background-color: hsl(var(--dashboard-bg) / 0.3);
}

.kpi-modal-footer-left {
  display: flex;
  align-items: center;
  gap: 1rem;
}

.kpi-modal-selection-preview {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.875rem;
  color: hsl(var(--dashboard-text-muted));
}

.kpi-modal-selection-preview-badges {
  display: flex;
  align-items: center;
  gap: -0.25rem;
}

.kpi-modal-option-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.5rem;
  margin-bottom: 0.5rem;
}

.kpi-modal-option-metrics {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-top: 0.5rem;
}

.kpi-modal-option-metric {
  display: flex;
  align-items: center;
  gap: 0.25rem;
}

.kpi-modal-option-metric-label,
.kpi-modal-option-vs {
  font-size: 0.625rem;
  color: hsl(var(--dashboard-text-muted));
}

.kpi-modal-dot {
  width: 0.5rem;
  height: 0.5rem;
  border-radius: 50%;
  background-color: hsl(var(--dashboard-accent));
}

.kpi-modal-dot.color-workspace-color-1 { background-color: hsl(var(--workspace-color-1)); }
.kpi-modal-dot.color-workspace-color-2 { background-color: hsl(var(--workspace-color-2)); }
.kpi-modal-dot.color-workspace-color-3 { background-color: hsl(var(--workspace-color-3)); }
.kpi-modal-dot.color-workspace-color-4 { background-color: hsl(var(--workspace-color-4)); }
.kpi-modal-dot.color-workspace-color-5 { background-color: hsl(var(--workspace-color-5)); }
.kpi-modal-dot.color-workspace-color-6 { background-color: hsl(var(--workspace-color-6)); }
.kpi-modal-dot.color-workspace-color-7 { background-color: hsl(var(--workspace-color-7)); }
.kpi-modal-dot.color-workspace-color-8 { background-color: hsl(var(--workspace-color-8)); }
.kpi-modal-dot.color-destructive { background-color: hsl(var(--destructive)); }

.kpi-modal-checkmark {
  color: hsl(var(--dashboard-accent));
}

.kpi-modal-selection-badge {
  width: 1.5rem;
  height: 1.5rem;
  border-radius: 50%;
  background-color: hsl(var(--dashboard-accent) / 0.2);
  border: 2px solid hsl(var(--dashboard-card));
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.625rem;
  font-weight: 700;
  color: hsl(var(--dashboard-accent));
}

.kpi-modal-selection-badge:not(:first-child) {
  margin-left: -0.25rem;
}

.kpi-modal-selection-badge.overflow {
  background-color: hsl(var(--dashboard-accent));
  color: hsl(var(--dashboard-bg));
}

.kpi-modal-clear {
  background: none;
  border: none;
  padding: 0.25rem 0.5rem;
  cursor: pointer;
  color: hsl(0 84% 60%);
  font-size: 0.75rem;
  display: flex;
  align-items: center;
  gap: 0.25rem;
  transition: all 0.2s;
  border-radius: calc(var(--radius) - 4px);
}

.kpi-modal-clear:hover {
  background-color: hsl(0 84% 60% / 0.1);
  color: hsl(0 84% 60%);
}

.kpi-modal-clear svg {
  width: 0.75rem;
  height: 0.75rem;
}

.kpi-modal-footer-right {
  display: flex;
  gap: 0.75rem;
}

.kpi-modal-cancel,
.kpi-modal-apply {
  padding: 0.5rem 1.5rem;
  border-radius: calc(var(--radius) - 2px);
  font-size: 0.875rem;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.2s;
  border: 1px solid;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.kpi-modal-cancel {
  background: none;
  border-color: hsl(var(--dashboard-border));
  color: hsl(var(--dashboard-text));
}

.kpi-modal-cancel:hover {
  background-color: hsl(var(--dashboard-bg));
}

.kpi-modal-apply {
  background-color: hsl(var(--dashboard-accent));
  border-color: hsl(var(--dashboard-accent));
  color: hsl(var(--dashboard-bg));
  box-shadow: 0 10px 15px -3px hsl(var(--dashboard-accent) / 0.3), 0 4px 6px -2px hsl(var(--dashboard-accent) / 0.3);
}

.kpi-modal-apply:hover {
  background-color: hsl(var(--dashboard-accent) / 0.9);
}

.kpi-modal-apply svg {
  width: 1rem;
  height: 1rem;
}

.meta-add-charts-wrapper {
  display: flex;
  gap: 0.5rem;
}

/* KPI Info Icon - Shared across all dashboards */
.kpi-info-icon {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1rem;
  height: 1rem;
  cursor: help;
  color: hsl(var(--dashboard-text-muted));
  transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
  flex-shrink: 0;
  border-radius: 50%;
  background-color: transparent;
  z-index: 1;
}

.kpi-info-icon:hover {
  color: hsl(var(--dashboard-accent));
  background-color: hsl(var(--dashboard-accent) / 0.1);
  transform: scale(1.1);
}

.kpi-info-icon:focus {
  outline: 2px solid hsl(var(--dashboard-accent) / 0.5);
  outline-offset: 2px;
  border-radius: 50%;
}

.kpi-info-icon svg {
  width: 100%;
  height: 100%;
}

.kpi-tooltip {
  position: absolute;
  bottom: calc(100% + 0.75rem);
  left: 50%;
  transform: translateX(-50%);
  background-color: hsl(var(--popover));
  border: 1px solid hsl(var(--dashboard-border) / 0.4);
  border-top: 2px solid hsl(var(--dashboard-accent) / 0.6);
  border-radius: calc(var(--radius) - 2px);
  padding: 0.875rem 1rem;
  font-size: 0.8125rem;
  font-weight: 400;
  color: hsl(var(--popover-foreground));
  white-space: nowrap;
  z-index: 9999;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity 0.25s cubic-bezier(0.4, 0, 0.2, 1), visibility 0.25s cubic-bezier(0.4, 0, 0.2, 1), transform 0.25s cubic-bezier(0.4, 0, 0.2, 1);
  transform: translateX(-50%) translateY(-0.375rem);
  box-shadow: 0 10px 15px -3px hsl(var(--a11y-shadow) / 0.15), 0 4px 6px -2px hsl(var(--a11y-shadow) / 0.1), 0 0 0 1px hsl(var(--dashboard-border) / 0.1);
  max-width: 20rem;
  min-width: 14rem;
  white-space: normal;
  text-align: left;
  line-height: 1.6;
  letter-spacing: 0.01em;
  word-wrap: break-word;
}

/* Tooltip positioning variants */
.kpi-tooltip.tooltip-top {
  bottom: calc(100% + 0.75rem);
  top: auto;
  border-top: 2px solid hsl(var(--dashboard-accent) / 0.6);
  border-bottom: 1px solid hsl(var(--dashboard-border) / 0.4);
}

.kpi-tooltip.tooltip-bottom {
  top: calc(100% + 0.75rem);
  bottom: auto;
  border-bottom: 2px solid hsl(var(--dashboard-accent) / 0.6);
  border-top: 1px solid hsl(var(--dashboard-border) / 0.4);
}

.kpi-tooltip.tooltip-left {
  left: auto;
  right: calc(100% + 0.75rem);
  transform: translateX(0) translateY(-50%);
  top: 50%;
  bottom: auto;
  border-left: 2px solid hsl(var(--dashboard-accent) / 0.6);
  border-right: 1px solid hsl(var(--dashboard-border) / 0.4);
  border-top: 1px solid hsl(var(--dashboard-border) / 0.4);
  border-bottom: 1px solid hsl(var(--dashboard-border) / 0.4);
}

.kpi-tooltip.tooltip-right {
  left: calc(100% + 0.75rem);
  right: auto;
  transform: translateX(0) translateY(-50%);
  top: 50%;
  bottom: auto;
  border-right: 2px solid hsl(var(--dashboard-accent) / 0.6);
  border-left: 1px solid hsl(var(--dashboard-border) / 0.4);
  border-top: 1px solid hsl(var(--dashboard-border) / 0.4);
  border-bottom: 1px solid hsl(var(--dashboard-border) / 0.4);
}

.kpi-info-icon:hover .kpi-tooltip,
.kpi-info-icon:focus .kpi-tooltip {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

.kpi-info-icon:hover .kpi-tooltip.tooltip-top,
.kpi-info-icon:focus .kpi-tooltip.tooltip-top {
  transform: translateX(-50%) translateY(0);
}

.kpi-info-icon:hover .kpi-tooltip.tooltip-bottom,
.kpi-info-icon:focus .kpi-tooltip.tooltip-bottom {
  transform: translateX(-50%) translateY(0);
}

.kpi-info-icon:hover .kpi-tooltip.tooltip-left,
.kpi-info-icon:focus .kpi-tooltip.tooltip-left {
  transform: translateX(0) translateY(-50%);
}

.kpi-info-icon:hover .kpi-tooltip.tooltip-right,
.kpi-info-icon:focus .kpi-tooltip.tooltip-right {
  transform: translateX(0) translateY(-50%);
}

.kpi-tooltip::selection {
  background-color: hsl(var(--dashboard-accent) / 0.3);
  color: hsl(var(--popover-foreground));
}

/* Arrow for top position (default) */
.kpi-tooltip.tooltip-top::after,
.kpi-tooltip:not(.tooltip-bottom):not(.tooltip-left):not(.tooltip-right)::after {
  content: '';
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  border: 0.5rem solid transparent;
  border-top-color: hsl(var(--popover));
  filter: drop-shadow(0 2px 2px hsl(var(--a11y-shadow) / 0.1));
}

.kpi-tooltip.tooltip-top::before,
.kpi-tooltip:not(.tooltip-bottom):not(.tooltip-left):not(.tooltip-right)::before {
  content: '';
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  border: 0.5625rem solid transparent;
  border-top-color: hsl(var(--dashboard-border) / 0.4);
  margin-top: 0.0625rem;
  filter: drop-shadow(0 1px 1px hsl(var(--a11y-shadow) / 0.05));
}

/* Arrow for bottom position */
.kpi-tooltip.tooltip-bottom::after {
  content: '';
  position: absolute;
  bottom: 100%;
  top: auto;
  left: 50%;
  transform: translateX(-50%);
  border: 0.5rem solid transparent;
  border-bottom-color: hsl(var(--popover));
  filter: drop-shadow(0 -2px 2px hsl(var(--a11y-shadow) / 0.1));
}

.kpi-tooltip.tooltip-bottom::before {
  content: '';
  position: absolute;
  bottom: 100%;
  top: auto;
  left: 50%;
  transform: translateX(-50%);
  border: 0.5625rem solid transparent;
  border-bottom-color: hsl(var(--dashboard-border) / 0.4);
  margin-bottom: 0.0625rem;
  filter: drop-shadow(0 -1px 1px hsl(var(--a11y-shadow) / 0.05));
}

/* Arrow for left position */
.kpi-tooltip.tooltip-left::after {
  content: '';
  position: absolute;
  left: 100%;
  right: auto;
  top: 50%;
  transform: translateY(-50%);
  border: 0.5rem solid transparent;
  border-left-color: hsl(var(--popover));
  filter: drop-shadow(2px 0 2px hsl(var(--a11y-shadow) / 0.1));
}

.kpi-tooltip.tooltip-left::before {
  content: '';
  position: absolute;
  left: 100%;
  right: auto;
  top: 50%;
  transform: translateY(-50%);
  border: 0.5625rem solid transparent;
  border-left-color: hsl(var(--dashboard-border) / 0.4);
  margin-left: 0.0625rem;
  filter: drop-shadow(1px 0 1px hsl(var(--a11y-shadow) / 0.05));
}

/* Arrow for right position */
.kpi-tooltip.tooltip-right::after {
  content: '';
  position: absolute;
  right: 100%;
  left: auto;
  top: 50%;
  transform: translateY(-50%);
  border: 0.5rem solid transparent;
  border-right-color: hsl(var(--popover));
  filter: drop-shadow(-2px 0 2px hsl(var(--a11y-shadow) / 0.1));
}

.kpi-tooltip.tooltip-right::before {
  content: '';
  position: absolute;
  right: 100%;
  left: auto;
  top: 50%;
  transform: translateY(-50%);
  border: 0.5625rem solid transparent;
  border-right-color: hsl(var(--dashboard-border) / 0.4);
  margin-right: 0.0625rem;
  filter: drop-shadow(-1px 0 1px hsl(var(--a11y-shadow) / 0.05));
}

.meta-kpi-loading-skeleton {
  position: relative;
  color: hsl(var(--dashboard-text-muted));
  overflow: hidden;
}

.meta-kpi-loading-skeleton::after {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(
    90deg,
    transparent,
    hsl(var(--dashboard-accent) / 0.1),
    transparent
  );
  animation: meta-kpi-skeleton-loading 1.5s infinite;
}

@keyframes meta-kpi-skeleton-loading {
  0% {
    left: -100%;
  }
  100% {
    left: 100%;
  }
}

.meta-kpi-loading {
  display: inline-block;
  width: 2rem;
  height: 0.75rem;
  background-color: hsl(var(--dashboard-text-muted) / 0.3);
  border-radius: 0.25rem;
  position: relative;
  overflow: hidden;
}

.meta-kpi-loading::after {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(
    90deg,
    transparent,
    hsl(var(--dashboard-accent) / 0.2),
    transparent
  );
  animation: meta-kpi-skeleton-loading 1.5s infinite;
}

.meta-empty-state {
  text-align: center;
  padding: 3rem;
}

.meta-empty-state h2 {
  font-size: 1.5rem;
  font-weight: 600;
  color: hsl(var(--dashboard-text));
  margin: 0 0 0.75rem 0;
}

.meta-connect-btn {
  margin-top: 1rem;
}

.meta-tabs-wrapper {
  margin-top: 2rem;
}

.meta-tabs-header {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 0.75rem;
  margin-bottom: 1.5rem;
  flex-wrap: wrap;
}

.meta-add-charts-wrapper {
  position: relative;
}

.meta-add-charts-btn {
  flex-shrink: 0;
  opacity: 0;
  transform: translateX(-1rem);
  pointer-events: none;
  transition: all 0.3s ease-in-out;
}

.meta-add-charts-btn.meta-add-charts-btn-visible {
  opacity: 1;
  transform: translateX(0);
  pointer-events: auto;
}

.meta-add-charts-popover {
  position: absolute;
  top: calc(100% + 0.5rem);
  right: 0;
  background-color: hsl(var(--dashboard-card));
  border: 1px solid hsl(var(--dashboard-border) / 0.3);
  border-radius: calc(var(--radius) - 2px);
  padding: 1rem;
  min-width: 16rem;
  z-index: 50;
  display: none;
  box-shadow: 0 4px 6px -1px hsl(var(--a11y-shadow) / 0.1), 0 2px 4px -1px hsl(var(--a11y-shadow) / 0.06);
}

.meta-add-charts-popover.show {
  display: block;
}

.meta-add-charts-popover-title {
  font-size: 0.875rem;
  font-weight: 600;
  color: hsl(var(--dashboard-text));
  margin: 0 0 0.75rem 0;
}

.meta-add-charts-options {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.meta-add-charts-checkbox-label {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  cursor: pointer;
  font-size: 0.875rem;
  color: hsl(var(--dashboard-text));
}

.meta-add-charts-checkbox {
  width: 1rem;
  height: 1rem;
  cursor: pointer;
  accent-color: hsl(var(--dashboard-accent));
}

.meta-charts-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.75rem;
  box-sizing: border-box;
  max-width: 100%;
}

/* Layout switcher wrapper - only visible on overview tab */
.meta-chart-layout-switcher-wrapper {
  display: flex;
  align-items: center;
  opacity: 0;
  transform: translateX(1rem);
  pointer-events: none;
  transition: all 0.3s ease-in-out;
}

.meta-tabs-header[data-active-tab="overview"] .meta-chart-layout-switcher-wrapper {
  opacity: 1;
  transform: translateX(0);
  pointer-events: auto;
}

/* Chart Layout Switcher - matches systemv styling */
.meta-chart-layout-switcher {
  display: flex;
  align-items: center;
  background-color: hsl(var(--dashboard-card) / 0.5);
  backdrop-filter: blur(4px);
  border: 1px solid hsl(var(--dashboard-border) / 0.3);
  border-radius: calc(var(--radius) - 2px);
  padding: 0.25rem;
  height: 2.5rem;
  gap: 0;
}

.meta-chart-layout-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 100%;
  border-radius: calc(var(--radius) - 4px);
  background-color: transparent;
  border: none;
  color: hsl(var(--dashboard-text-muted));
  cursor: pointer;
  transition: all 0.2s;
  padding: 0;
}

.meta-chart-layout-btn:hover {
  color: hsl(var(--dashboard-accent));
}

.meta-chart-layout-btn.active {
  background-color: hsl(var(--dashboard-accent));
  color: hsl(var(--dashboard-bg));
}

.meta-chart-layout-btn svg {
  width: 1rem;
  height: 1rem;
  display: block;
}

/* Grid layouts - 1, 2, or 3 columns */
.meta-charts-grid[data-columns="1"] {
  grid-template-columns: 1fr;
}

.meta-charts-grid[data-columns="2"] {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.meta-charts-grid[data-columns="3"] {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

/* Responsive: default to 1 column on mobile, 2 on tablet+ */
@media (min-width: 1024px) {
  .meta-charts-grid:not([data-columns]) {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  
  .meta-charts-grid[data-columns="1"] {
    grid-template-columns: 1fr;
  }
  
  .meta-charts-grid[data-columns="2"] {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  
  .meta-charts-grid[data-columns="3"] {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

.meta-chart-card {
  padding: 0;
  border-color: hsl(var(--dashboard-border) / 0.3);
  background-color: hsl(var(--dashboard-card));
  color: hsl(var(--dashboard-text));
  box-sizing: border-box;
  max-width: 100%;
  min-width: 0;
  overflow: hidden;
}

/* Inner content padding - matches systemv p-2 (0.5rem) for 2 columns */
.meta-chart-card > div {
  padding: 0.5rem;
}

/* For 3 columns, use p-1.5 (0.375rem) - applied via class or JS */
.meta-chart-card.compact > div {
  padding: 0.375rem;
}

/* When grid is in 3-column mode, adjust padding and font sizes */
.meta-charts-grid[data-columns="3"] .meta-chart-card > div {
  padding: 0.375rem;
}

.meta-charts-grid[data-columns="3"] .meta-chart-title {
  font-size: 0.625rem;
}

/* Chart height adjustments for different column layouts */
.meta-charts-grid[data-columns="1"] .meta-chart-container {
  height: 320px;
}

.meta-charts-grid[data-columns="2"] .meta-chart-container {
  height: 280px;
}

.meta-charts-grid[data-columns="3"] .meta-chart-container {
  height: 220px;
}

/* Generic Add Card - Reusable across all platforms */
.add-card {
  background-color: hsl(var(--dashboard-card));
  border: 2px dashed hsl(var(--dashboard-border) / 0.5);
  border-radius: var(--radius);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all 0.3s;
  box-sizing: border-box;
}

.add-card:hover {
  border-color: hsl(var(--dashboard-accent) / 0.6);
  box-shadow: 0 10px 15px -3px hsl(var(--dashboard-accent) / 0.2), 0 4px 6px -2px hsl(var(--dashboard-accent) / 0.2);
  background-color: hsl(var(--dashboard-accent) / 0.05);
}

/* Default size - for charts */
.add-card {
  height: 100%;
  min-height: 280px;
  gap: 0.75rem;
}

/* Compact variant - for KPIs */
.add-card-compact {
  padding: 0.75rem 1rem;
  gap: 0.5rem;
  min-height: 88px;
}

.add-card-icon-wrapper {
  border-radius: 50%;
  background-color: hsl(var(--dashboard-accent) / 0.1);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.3s;
}

/* Default icon wrapper size - for charts */
.add-card .add-card-icon-wrapper {
  width: 3rem;
  height: 3rem;
}

/* Compact icon wrapper size - for KPIs */
.add-card-compact .add-card-icon-wrapper {
  width: 2.5rem;
  height: 2.5rem;
}

.add-card:hover .add-card-icon-wrapper {
  background-color: hsl(var(--dashboard-accent) / 0.2);
  transform: scale(1.1);
}

.add-card-icon {
  color: hsl(var(--dashboard-accent));
}

/* Default icon size - for charts */
.add-card .add-card-icon {
  width: 1.5rem;
  height: 1.5rem;
}

/* Compact icon size - for KPIs */
.add-card-compact .add-card-icon {
  width: 1.25rem;
  height: 1.25rem;
}

.add-card-text {
  text-align: center;
}

.add-card-title {
  font-weight: 500;
  color: hsl(var(--dashboard-text));
  margin: 0;
  transition: color 0.3s;
}

/* Default title size - for charts */
.add-card .add-card-title {
  font-size: 0.875rem;
}

/* Compact title size - for KPIs */
.add-card-compact .add-card-title {
  font-size: 0.75rem;
}

.add-card:hover .add-card-title {
  color: hsl(var(--dashboard-accent));
}

.add-card-subtitle {
  color: hsl(var(--dashboard-text-muted));
  margin: 0;
}

/* Default subtitle size - for charts */
.add-card .add-card-subtitle {
  font-size: 0.75rem;
  margin-top: 0.125rem;
}

/* Compact subtitle size - for KPIs */
.add-card-compact .add-card-subtitle {
  font-size: 0.625rem;
}

.meta-chart-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.5rem;
  margin-bottom: 0.375rem;
}

/* Title container - matches systemv flex items-center gap-1.5 min-w-0 flex-shrink */
.meta-chart-title-wrapper {
  display: flex;
  align-items: center;
  gap: 0.375rem;
  min-width: 0;
  flex-shrink: 1;
}

.chart-type-switcher-wrapper {
  display: flex;
  align-items: center;
  gap: 0.25rem;
  flex-shrink: 0;
}

.meta-chart-title {
  font-size: 0.75rem;
  font-weight: 600;
  color: hsl(var(--dashboard-text));
  margin: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  flex-shrink: 1;
  min-width: 0;
}

/* Chart Info Tooltip Button - matches systemv */
.chart-info-tooltip-btn {
  padding: 0.25rem;
  border-radius: 50%;
  background-color: transparent;
  border: none;
  color: hsl(var(--dashboard-text-muted));
  cursor: pointer;
  transition: all 0.2s;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  flex-shrink: 0;
}

.chart-info-tooltip-btn:hover {
  background-color: hsl(var(--dashboard-accent) / 0.1);
  color: hsl(var(--dashboard-accent));
}

.chart-info-icon {
  width: 1rem;
  height: 1rem;
  display: block;
}

/* Chart Info Tooltip Popup */
.chart-info-tooltip {
  position: absolute;
  top: calc(100% + 0.5rem);
  left: 0;
  background-color: hsl(var(--dashboard-card));
  border: 1px solid hsl(var(--dashboard-border) / 0.6);
  border-radius: calc(var(--radius) - 2px);
  padding: 0.75rem;
  max-width: 20rem;
  min-width: 16rem;
  width: max-content;
  z-index: 9999;
  box-shadow: 0 10px 15px -3px hsl(var(--a11y-shadow) / 0.1), 0 4px 6px -2px hsl(var(--a11y-shadow) / 0.1);
  display: none;
  pointer-events: none;
  word-wrap: break-word;
  overflow-wrap: break-word;
}

.chart-info-tooltip-btn:hover .chart-info-tooltip,
.chart-info-tooltip-btn:focus .chart-info-tooltip {
  display: block;
  pointer-events: auto;
}

.chart-info-tooltip-header {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 0.5rem;
  padding-bottom: 0.5rem;
  border-bottom: 1px solid hsl(var(--dashboard-border) / 0.3);
}

.chart-info-tooltip-icon-wrapper {
  padding: 0.375rem;
  background-color: hsl(var(--dashboard-accent));
  border-radius: calc(var(--radius) - 4px);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.chart-info-tooltip-icon-wrapper svg {
  width: 0.75rem;
  height: 0.75rem;
  color: hsl(var(--dashboard-bg));
}

.chart-info-tooltip-title {
  font-size: 0.875rem;
  font-weight: 600;
  color: hsl(var(--dashboard-text));
  margin: 0;
  word-wrap: break-word;
  overflow-wrap: break-word;
  min-width: 0;
}

.chart-info-tooltip-body {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  min-width: 0;
}

.chart-info-tooltip-section {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.chart-info-tooltip-section-header {
  display: flex;
  align-items: center;
  gap: 0.375rem;
}

.chart-info-tooltip-icon-blue {
  padding: 0.25rem;
  background-color: hsl(217 91% 60% / 0.2);
  border-radius: calc(var(--radius) - 4px);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.chart-info-tooltip-icon-blue svg {
  width: 0.75rem;
  height: 0.75rem;
  color: hsl(217 91% 60%);
}

.chart-info-tooltip-icon-green {
  padding: 0.25rem;
  background-color: hsl(142 76% 36% / 0.2);
  border-radius: calc(var(--radius) - 4px);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.chart-info-tooltip-icon-green svg {
  width: 0.75rem;
  height: 0.75rem;
  color: hsl(142 76% 36%);
}

.chart-info-tooltip-section-label {
  font-size: 0.625rem;
  font-weight: 600;
  color: hsl(var(--dashboard-accent));
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin: 0;
}

.chart-info-tooltip-section-text {
  font-size: 0.75rem;
  color: hsl(var(--dashboard-text-muted));
  margin: 0;
  line-height: 1.5;
  padding-left: 1.25rem;
  word-wrap: break-word;
  overflow-wrap: break-word;
  min-width: 0;
}

.chart-info-tooltip-action {
  padding: 0.5rem;
  background-color: hsl(var(--dashboard-accent) / 0.1);
  border: 1px solid hsl(var(--dashboard-accent) / 0.3);
  border-radius: calc(var(--radius) - 2px);
  display: flex;
  align-items: flex-start;
  gap: 0.5rem;
  min-width: 0;
}

.chart-info-tooltip-action-icon {
  margin-top: 0.125rem;
  width: 1rem;
  height: 1rem;
  border-radius: 50%;
  background-color: hsl(var(--dashboard-accent) / 0.3);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.chart-info-tooltip-action-icon span {
  font-size: 0.5rem;
  font-weight: 700;
  color: hsl(var(--dashboard-accent));
}

.chart-info-tooltip-action-label {
  font-size: 0.625rem;
  font-weight: 600;
  color: hsl(var(--dashboard-accent));
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin: 0 0 0.125rem 0;
}

.chart-info-tooltip-action-text {
  font-size: 0.75rem;
  color: hsl(var(--dashboard-text));
  margin: 0;
  line-height: 1.5;
  word-wrap: break-word;
  overflow-wrap: break-word;
  min-width: 0;
}

/* Chart Type Switcher - matches systemv */
.chart-type-switcher {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.chart-type-switcher-active {
  padding: 0.25rem;
  border-radius: calc(var(--radius) - 4px);
  background-color: transparent;
  border: none;
  color: hsl(var(--dashboard-accent));
  cursor: pointer;
  transition: all 0.2s;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.chart-type-switcher-active:hover {
  background-color: hsl(var(--dashboard-accent) / 0.1);
}

.chart-type-switcher-active svg {
  width: 0.875rem;
  height: 0.875rem;
  display: block;
}

.chart-type-switcher-options {
  position: absolute;
  top: calc(100% + 0.25rem);
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.125rem;
  overflow: hidden;
  background-color: hsl(var(--dashboard-card));
  border: 1px solid hsl(var(--dashboard-border) / 0.5);
  border-radius: calc(var(--radius) - 4px);
  box-shadow: 0 10px 15px -3px hsl(var(--a11y-shadow) / 0.1), 0 4px 6px -2px hsl(var(--a11y-shadow) / 0.1);
  z-index: 50;
  max-height: 0;
  opacity: 0;
  padding: 0;
  margin-top: 0;
  border-width: 0;
  transition: all 0.3s ease-out;
}

.chart-type-switcher:hover .chart-type-switcher-options {
  max-height: 8rem;
  opacity: 1;
  padding: 0.25rem;
  margin-top: 0.25rem;
  border-width: 1px;
}

.chart-type-option {
  padding: 0.375rem;
  background-color: transparent;
  border: none;
  border-radius: calc(var(--radius) - 4px);
  color: hsl(var(--dashboard-text-muted));
  cursor: pointer;
  transition: all 0.2s;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
}

.chart-type-option:hover {
  color: hsl(var(--dashboard-accent));
  background-color: hsl(var(--dashboard-accent) / 0.1);
}

.chart-type-option svg {
  width: 0.875rem;
  height: 0.875rem;
  display: block;
}
  cursor: pointer;
  transition: all 0.2s;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

/* Legacy Meta classes - aliases to shared classes for backward compatibility */
.meta-chart-type-switcher {
  position: relative;
  display: flex;
  align-items: center;
}

.meta-chart-type-options,
.meta-chart-type-switcher:hover .meta-chart-type-options {
  display: flex;
  align-items: center;
  gap: 0.25rem;
  overflow: hidden;
  max-width: 0;
  opacity: 0;
  margin-right: 0;
  transition: all 0.3s ease-out;
}

.meta-chart-type-switcher:hover .meta-chart-type-options {
  max-width: 6rem;
  opacity: 1;
  margin-right: 0.25rem;
}

.meta-chart-type-btn {
  padding: 0.375rem;
  background-color: hsl(var(--dashboard-bg));
  border: 1px solid hsl(var(--dashboard-border) / 0.3);
  border-radius: calc(var(--radius) - 2px);
  color: hsl(var(--dashboard-text-muted));
  cursor: pointer;
  transition: all 0.2s;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Hide option buttons that match the active type (handled by JavaScript) */
.meta-chart-type-options .meta-chart-type-btn[style*="display: none"] {
  display: none;
  visibility: hidden;
  max-width: 0;
  opacity: 0;
  margin: 0;
  padding: 0;
  overflow: hidden;
}

.meta-chart-type-btn:hover {
  color: hsl(var(--dashboard-accent));
  border-color: hsl(var(--dashboard-accent) / 0.5);
}

.meta-chart-type-btn-active {
  padding: 0.375rem;
  background-color: hsl(var(--dashboard-accent));
  border: none;
  border-radius: calc(var(--radius) - 2px);
  color: hsl(var(--accent-foreground));
  cursor: pointer;
  transition: all 0.2s;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.meta-chart-container {
  position: relative;
  height: 280px;
  width: 100%;
  box-sizing: border-box;
  max-width: 100%;
  min-width: 0;
  background-color: transparent;
  overflow: hidden;
}

.meta-chart-container canvas {
  background-color: transparent;
  max-width: 100%;
  height: 100%;
}

.meta-chart-loading {
  position: relative;
}



/* ============================================
   Module: meta-dashboard.css
   ============================================ */

/* Chart Loading Spinner */
.chart-loading-spinner {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  background-color: hsl(var(--dashboard-card) / 0.8);
  z-index: 20;
  border-radius: calc(var(--radius) - 2px);
}

.chart-loading-spinner.hidden {
  display: none;
}

.chart-spinner {
  width: 40px;
  height: 40px;
  border: 3px solid hsl(var(--dashboard-border) / 0.3);
  border-top-color: hsl(var(--dashboard-accent));
  border-radius: 50%;
  animation: chart-spin 0.8s linear infinite;
  flex-shrink: 0;
}

.chart-loading-text {
  color: hsl(var(--dashboard-text-muted));
  font-size: 0.875rem;
  font-weight: 500;
  margin: 0;
  text-align: center;
}

@keyframes chart-spin {
  to {
    transform: rotate(360deg);
  }
}

.meta-chart-empty {
  position: relative;
  overflow: hidden;
}

.meta-chart-empty canvas {
  opacity: 0;
  pointer-events: none;
}

.meta-chart-empty .meta-chart-empty-message {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  color: hsl(var(--dashboard-text-muted));
  font-size: 0.875rem;
  text-align: center;
  z-index: 10;
  max-width: calc(100% - 2rem);
  width: 320px;
  padding: 0 1rem;
  line-height: 1.5;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  box-sizing: border-box;
}

.meta-chart-empty-icon {
  width: 32px;
  height: 32px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background-color: hsl(var(--dashboard-bg-subtle));
  color: hsl(var(--dashboard-text-muted));
}

.meta-chart-empty-title {
  font-size: 0.875rem;
  font-weight: 600;
  color: hsl(var(--dashboard-text));
}

.meta-chart-empty-description {
  font-size: 0.75rem;
  color: hsl(var(--dashboard-text-muted));
}

.meta-campaigns-loading,
.meta-campaigns-empty {
  padding: 2rem;
  text-align: center;
  color: hsl(var(--dashboard-text-muted));
  font-size: 0.875rem;
}

.meta-campaigns-table-loading,
.meta-campaigns-table-empty {
  padding: 3rem 1rem;
  text-align: center;
}

.meta-campaigns-loading-skeleton {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  padding: 1rem 0;
}

.meta-campaigns-loading-line {
  height: 1rem;
  background: linear-gradient(
    90deg,
    hsl(var(--dashboard-border) / 0.2) 0%,
    hsl(var(--dashboard-border) / 0.4) 50%,
    hsl(var(--dashboard-border) / 0.2) 100%
  );
  background-size: 200% 100%;
  animation: meta-campaigns-shimmer 1.5s ease-in-out infinite;
  border-radius: calc(var(--radius) - 4px);
}

.meta-campaigns-loading-line:nth-child(1) {
  width: 100%;
}

.meta-campaigns-loading-line:nth-child(2) {
  width: 85%;
}

.meta-campaigns-loading-line:nth-child(3) {
  width: 90%;
}

@keyframes meta-campaigns-shimmer {
  0% {
    background-position: -200% 0;
  }
  100% {
    background-position: 200% 0;
  }
}

.meta-campaigns-empty-message {
  color: hsl(var(--dashboard-text-muted));
  font-size: 0.875rem;
}

.meta-campaigns-empty-message p {
  margin: 0;
}

/* Meta Dashboard - Top Campaigns */
.meta-top-campaigns-card {
  margin-top: 1.5rem;
  padding: 1.5rem;
  border-color: hsl(var(--dashboard-border) / 0.3);
}

.meta-top-campaigns-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 1rem;
}

.meta-top-campaigns-title {
  font-size: 1.125rem;
  font-weight: 600;
  color: hsl(var(--dashboard-text));
  margin: 0;
}


.meta-top-campaigns-list {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.meta-top-campaign-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1rem;
  background-color: hsl(var(--dashboard-bg));
  border: 1px solid hsl(var(--dashboard-border) / 0.3);
  border-radius: calc(var(--radius) - 2px);
  transition: border-color 0.2s;
}

.meta-top-campaign-item:hover {
  border-color: hsl(var(--dashboard-accent) / 0.4);
}

.meta-top-campaign-left {
  display: flex;
  align-items: center;
  gap: 1rem;
}

.meta-top-campaign-platform-icon {
  width: 1rem;
  height: 1rem;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  gap: 0.25rem;
}

.meta-top-campaign-platform-icon svg {
  width: 1rem;
  height: 1rem;
  flex-shrink: 0;
}

.meta-platform-icon-facebook {
  color: hsl(var(--platform-meta));
}

.meta-platform-icon-instagram {
  color: hsl(330 81% 60%);
}

.meta-top-campaign-platform-both {
  display: flex;
  gap: 0.25rem;
}

/* ============================================
   Meta Dashboard - Campaigns & Audience Tab
   ============================================ */

.meta-campaigns-card {
  padding: 1.5rem;
  border-color: hsl(var(--dashboard-border) / 0.3);
}

.meta-campaigns-header {
  margin-bottom: 1.5rem;
}

.meta-campaigns-filters {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  flex-wrap: wrap;
}

.meta-campaigns-search-wrapper {
  position: relative;
  flex: 0 0 auto;
}

.meta-campaigns-search-icon {
  position: absolute;
  left: 0.75rem;
  top: 50%;
  transform: translateY(-50%);
  width: 1rem;
  height: 1rem;
  color: hsl(var(--dashboard-text-muted));
  pointer-events: none;
}

.meta-campaigns-search {
  padding-left: 2.5rem;
  width: 16rem;
}

.meta-campaigns-filters-dropdown {
  position: relative;
}

.meta-campaigns-filters-popover {
  position: absolute;
  top: calc(100% + 0.5rem);
  left: 0;
  background-color: hsl(var(--dashboard-card));
  border: 1px solid hsl(var(--dashboard-border) / 0.3);
  border-radius: calc(var(--radius) - 2px);
  padding: 0.5rem;
  min-width: 8rem;
  z-index: 50;
  display: none;
  flex-direction: column;
  gap: 0.25rem;
  box-shadow: 0 4px 6px -1px hsl(var(--a11y-shadow) / 0.1), 0 2px 4px -1px hsl(var(--a11y-shadow) / 0.06);
}

.meta-campaigns-filters-popover.show {
  display: flex;
}

.meta-campaigns-filter-option {
  padding: 0.5rem 0.75rem;
  text-align: left;
  background-color: transparent;
  border: none;
  color: hsl(var(--dashboard-text));
  cursor: pointer;
  border-radius: calc(var(--radius) - 4px);
  font-size: 0.875rem;
  transition: all 0.2s;
}

.meta-campaigns-filter-option:hover {
  background-color: hsl(var(--dashboard-accent) / 0.1);
  color: hsl(var(--dashboard-text));
}

.meta-campaigns-table-wrapper {
  overflow-x: auto;
}

.meta-campaigns-table {
  width: 100%;
  border-collapse: collapse;
}

.meta-campaigns-table thead {
  border-bottom: 1px solid hsl(var(--dashboard-border) / 0.3);
}

.meta-campaigns-table th {
  padding: 0.75rem 1rem;
  text-align: left;
  font-size: 0.875rem;
  font-weight: 500;
  color: hsl(var(--dashboard-text-muted));
}

.meta-campaigns-table tbody tr {
  border-bottom: 1px solid hsl(var(--dashboard-border) / 0.2);
  transition: background-color 0.2s;
}

.meta-campaigns-table tbody tr:hover {
  background-color: hsl(var(--dashboard-bg) / 0.5);
}

.meta-campaigns-table tbody tr.selected {
  background-color: hsl(var(--dashboard-accent) / 0.1);
  border-color: hsl(var(--dashboard-accent) / 0.3);
}

.meta-campaigns-table td {
  padding: 1rem;
  font-size: 0.875rem;
  color: hsl(var(--dashboard-text));
}

.meta-campaign-name {
  font-weight: 500;
  color: hsl(var(--dashboard-text));
  margin: 0 0 0.25rem 0;
}

.meta-campaign-objective {
  font-size: 0.75rem;
  color: hsl(var(--dashboard-text-muted));
  margin: 0;
}

.meta-campaign-status-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  padding: 0.25rem 0.5rem;
  border-radius: calc(var(--radius) - 4px);
  font-size: 0.75rem;
  font-weight: 500;
  border: 1px solid;
}

.meta-campaign-status-badge.active {
  background-color: hsl(142 71% 45% / 0.2);
  color: hsl(142 71% 45%);
  border-color: hsl(142 71% 45% / 0.5);
}

.meta-campaign-status-badge.paused {
  background-color: hsl(45 93% 47% / 0.2);
  color: hsl(45 93% 47%);
  border-color: hsl(45 93% 47% / 0.5);
}

.meta-campaign-status-badge.off {
  background-color: hsl(var(--dashboard-border) / 0.2);
  color: hsl(var(--dashboard-text-muted));
  border-color: hsl(var(--dashboard-border) / 0.5);
}

.meta-campaign-status-badge svg {
  width: 0.75rem;
  height: 0.75rem;
}

.meta-campaign-spent-wrapper {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 0.25rem;
}

.meta-campaign-spent-value {
  margin: 0;
}

.meta-campaign-spent-progress {
  width: 5rem;
  height: 0.25rem;
  background-color: hsl(var(--dashboard-border) / 0.3);
  border-radius: calc(var(--radius) - 4px);
  overflow: hidden;
}

.meta-campaign-spent-progress-bar {
  height: 100%;
  background-color: hsl(var(--dashboard-accent));
  transition: width 0.3s;
  width: 0%;
}

.meta-campaign-spent-progress-bar[data-width] {
  width: calc(var(--progress-width, 0) * 1%);
}

.meta-campaign-roas {
  color: hsl(142 71% 45%);
}

.meta-campaign-roas.zero {
  color: hsl(var(--dashboard-text-muted));
}

.meta-campaign-audience-btn {
  padding: 0.375rem;
  background-color: transparent;
  border: none;
  color: hsl(var(--dashboard-text-muted));
  cursor: pointer;
  border-radius: calc(var(--radius) - 4px);
  transition: all 0.2s;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.meta-campaign-audience-btn:hover {
  background-color: hsl(var(--dashboard-accent) / 0.1);
  color: hsl(var(--dashboard-text));
}

.meta-campaign-audience-btn.active {
  background-color: hsl(var(--dashboard-accent));
  color: hsl(0, 0%, 0%);
}

.meta-campaign-audience-btn svg {
  width: 1rem;
  height: 1rem;
}

.meta-campaign-actions {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
}

.meta-campaign-action-btn {
  padding: 0.375rem;
  width: 2rem;
  height: 2rem;
  background-color: transparent;
  border: none;
  color: hsl(var(--dashboard-text-muted));
  cursor: pointer;
  border-radius: calc(var(--radius) - 4px);
  transition: all 0.2s;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.meta-campaign-action-btn:hover {
  background-color: hsl(var(--dashboard-accent) / 0.1);
  color: hsl(var(--dashboard-text));
}

.meta-campaign-action-btn.delete:hover {
  background-color: hsl(0 84% 60% / 0.1);
  color: hsl(0 84% 60%);
}

.meta-campaign-action-btn svg {
  width: 1rem;
  height: 1rem;
}

/* Hierarchical Campaigns Table Styles */
.campaign-expand-btn,
.adset-expand-btn {
  border: none;
  background: transparent;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s;
}

.campaign-expand-btn:hover,
.adset-expand-btn:hover {
  background-color: hsl(var(--dashboard-accent) / 0.1);
}

.campaign-expand-btn svg,
.adset-expand-btn svg {
  transition: transform 0.2s;
}

/* Status badges with SystemV colors */
.inline-flex.items-center.rounded-full.border {
  display: inline-flex;
  align-items: center;
  border-radius: 9999px;
  border-width: 1px;
  font-size: 0.75rem;
  font-weight: 600;
  transition: all 0.2s;
}

.bg-green-500\/20 {
  background-color: hsl(142 71% 45% / 0.2);
}

.text-green-500 {
  color: hsl(142 71% 45%);
}

.border-green-500\/50 {
  border-color: hsl(142 71% 45% / 0.5);
}

.bg-yellow-500\/20 {
  background-color: hsl(45 93% 47% / 0.2);
}

.text-yellow-500 {
  color: hsl(45 93% 47%);
}

.border-yellow-500\/50 {
  border-color: hsl(45 93% 47% / 0.5);
}

.bg-orange-500\/20 {
  background-color: hsl(25 95% 53% / 0.2);
}

.text-orange-400 {
  color: hsl(25 95% 53%);
}

.border-orange-500\/50 {
  border-color: hsl(25 95% 53% / 0.5);
}

.bg-blue-500\/20 {
  background-color: hsl(217 91% 60% / 0.2);
}

.text-blue-400 {
  color: hsl(217 91% 60%);
}

.border-blue-500\/50 {
  border-color: hsl(217 91% 60% / 0.5);
}

.bg-gray-500\/20 {
  background-color: hsl(var(--dashboard-border) / 0.2);
}

.text-gray-400 {
  color: hsl(var(--dashboard-text-muted));
}

.border-gray-500\/50 {
  border-color: hsl(var(--dashboard-border) / 0.5);
}

/* Progress bar styles */
.relative.overflow-hidden.rounded-full.bg-secondary {
  position: relative;
  overflow: hidden;
  border-radius: 9999px;
  background-color: hsl(var(--secondary));
}

.h-full.w-full.flex-1.bg-primary {
  height: 100%;
  width: 100%;
  flex: 1 1 0%;
  background-color: hsl(var(--primary));
  transition: all 0.3s;
}

/* Text color utilities */
.text-dashboard-accent {
  color: hsl(var(--dashboard-accent));
}

.font-semibold {
  font-weight: 600;
}

.font-medium {
  font-weight: 500;
}

.font-bold {
  font-weight: 700;
}

.text-xs {
  font-size: 0.75rem;
  line-height: 1rem;
}

.text-sm {
  font-size: 0.875rem;
  line-height: 1.25rem;
}

/* Border utilities */
.border-b {
  border-bottom-width: 1px;
}

.border-dashboard-border\/20 {
  border-color: hsl(var(--dashboard-border) / 0.2);
}

.border-dashboard-border\/10 {
  border-color: hsl(var(--dashboard-border) / 0.1);
}

.border-dashboard-border\/30 {
  border-color: hsl(var(--dashboard-border) / 0.3);
}

/* Background utilities */
.bg-dashboard-card\/50 {
  background-color: hsl(var(--dashboard-card) / 0.5);
}

.bg-dashboard-bg\/30 {
  background-color: hsl(var(--dashboard-bg) / 0.3);
}

.bg-dashboard-bg\/50 {
  background-color: hsl(var(--dashboard-bg) / 0.5);
}

.bg-dashboard-bg\/70 {
  background-color: hsl(var(--dashboard-bg) / 0.7);
}

.hover\:bg-dashboard-bg\/70:hover {
  background-color: hsl(var(--dashboard-bg) / 0.7);
}

.hover\:bg-dashboard-bg\/50:hover {
  background-color: hsl(var(--dashboard-bg) / 0.5);
}

/* Padding utilities */
.py-3 {
  padding-top: 0.75rem;
  padding-bottom: 0.75rem;
}

.py-2\.5 {
  padding-top: 0.625rem;
  padding-bottom: 0.625rem;
}

.px-3 {
  padding-left: 0.75rem;
  padding-right: 0.75rem;
}

.pl-4 {
  padding-left: 1rem;
}

.pl-8 {
  padding-left: 2rem;
}

.pl-12 {
  padding-left: 3rem;
}

/* Spacing utilities */
.gap-1 {
  gap: 0.25rem;
}

.gap-1\.5 {
  gap: 0.375rem;
}

.gap-2 {
  gap: 0.5rem;
}

.gap-4 {
  gap: 1rem;
}

/* Flex utilities */
.flex {
  display: flex;
}

.items-center {
  align-items: center;
}

/* Width utilities */
.w-10 {
  width: 2.5rem;
}

.w-20 {
  width: 5rem;
}

.w-36 {
  width: 9rem;
}

.w-64 {
  width: 16rem;
}

.h-1 {
  height: 0.25rem;
}

.h-6 {
  height: 1.5rem;
}

.h-7 {
  height: 1.75rem;
}

.w-6 {
  width: 1.5rem;
}

.w-7 {
  width: 1.75rem;
}

.w-3 {
  width: 0.75rem;
}

.w-3\.5 {
  width: 0.875rem;
}

.w-4 {
  width: 1rem;
}

.h-3 {
  height: 0.75rem;
}

.h-3\.5 {
  height: 0.875rem;
}

.h-4 {
  height: 1rem;
}

/* Text alignment */
.text-left {
  text-align: left;
}

.text-right {
  text-align: right;
}

.text-center {
  text-align: center;
}

/* Whitespace */
.whitespace-nowrap {
  white-space: nowrap;
}

/* Transition */
.transition-colors {
  transition-property: color, background-color, border-color;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 150ms;
}

/* Icon colors */
.text-blue-400 {
  color: hsl(217 91% 60%);
}

.text-blue-500 {
  color: hsl(217 91% 60%);
}

.text-pink-500 {
  color: hsl(330 81% 60%);
}

.text-purple-400 {
  color: hsl(270 91% 65%);
}

/* Loading spinner */
.animate-spin {
  animation: spin 1s linear infinite;
}

@keyframes spin {
  from {
    transform: rotate(0deg);
  }
  to {
    transform: rotate(360deg);
  }
}

.rounded-full {
  border-radius: 9999px;
}

.h-4 {
  height: 1rem;
}

.w-4 {
  width: 1rem;
}

.border-2 {
  border-width: 2px;
}

.border-dashboard-border {
  border-color: hsl(var(--dashboard-border));
}

.border-t-dashboard-accent {
  border-top-color: hsl(var(--dashboard-accent));
}

/* Audience Insights Section */
.meta-audience-section {
  margin-top: 1.5rem;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.meta-audience-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 0.75rem;
}

.meta-audience-title {
  font-size: 1.125rem;
  font-weight: 600;
  color: hsl(var(--dashboard-text));
  margin: 0;
}

.meta-audience-view-all.hidden {
  display: none;
}

.meta-audience-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.5rem;
  box-sizing: border-box;
  max-width: 100%;
}

@media (min-width: 1024px) {
  .meta-audience-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

.meta-audience-card {
  padding: 1.5rem;
  border-color: hsl(var(--dashboard-border) / 0.3);
  box-sizing: border-box;
  max-width: 100%;
  min-width: 0;
}

.meta-audience-card-title {
  font-size: 1rem;
  font-weight: 600;
  color: hsl(var(--dashboard-text));
  margin: 0 0 1rem 0;
}

.meta-audience-chart-container {
  position: relative;
  height: 200px;
  width: 100%;
  box-sizing: border-box;
  max-width: 100%;
  min-width: 0;
}

.meta-audience-legend {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  justify-content: center;
  margin-top: 1.5rem;
  padding-top: 1rem;
}

.meta-audience-legend-item {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.meta-audience-legend-dot {
  width: 0.625rem;
  height: 0.625rem;
  border-radius: 50%;
  flex-shrink: 0;
  background-color: var(--legend-color, hsl(var(--dashboard-text-muted)));
}

.meta-audience-legend-dot[data-color] {
  background-color: var(--legend-color);
}

.meta-audience-legend-text {
  font-size: 0.875rem;
  color: hsl(var(--dashboard-text-muted));
}

.meta-audience-list {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  max-height: 300px;
  overflow-y: auto;
  padding-right: 0.25rem;
}

.meta-audience-list::-webkit-scrollbar {
  width: 0.375rem;
}

.meta-audience-list::-webkit-scrollbar-track {
  background: hsl(var(--dashboard-bg));
  border-radius: calc(var(--radius) - 4px);
}

.meta-audience-list::-webkit-scrollbar-thumb {
  background: hsl(var(--dashboard-border) / 0.5);
  border-radius: calc(var(--radius) - 4px);
}

.meta-audience-list::-webkit-scrollbar-thumb:hover {
  background: hsl(var(--dashboard-border));
}

.meta-audience-location-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.75rem;
  background-color: hsl(var(--dashboard-bg));
  border: 1px solid hsl(var(--dashboard-border) / 0.3);
  border-radius: calc(var(--radius) - 2px);
  flex-shrink: 0;
}

.meta-audience-location-name {
  font-size: 0.875rem;
  font-weight: 500;
  color: hsl(var(--dashboard-text));
  margin: 0;
}

.meta-audience-location-country {
  font-size: 0.75rem;
  color: hsl(var(--dashboard-text-muted));
  margin: 0.25rem 0 0 0;
}

.meta-audience-location-value {
  font-size: 0.875rem;
  font-weight: 600;
  color: hsl(var(--dashboard-accent));
  margin: 0;
}

.meta-top-campaign-name {
  font-size: 0.875rem;
  font-weight: 500;
  color: hsl(var(--dashboard-text));
  margin: 0 0 0.25rem 0;
}

.meta-top-campaign-objective {
  font-size: 0.75rem;
  color: hsl(var(--dashboard-text-muted));
  margin: 0;
}

.meta-top-campaign-metrics {
  display: flex;
  align-items: center;
  gap: 2rem;
}

.meta-top-campaign-metric {
  text-align: right;
}

.meta-top-campaign-metric-label {
  font-size: 0.75rem;
  color: hsl(var(--dashboard-text-muted));
  margin: 0 0 0.25rem 0;
}

.meta-top-campaign-metric-value {
  font-size: 0.875rem;
  font-weight: 500;
  color: hsl(var(--dashboard-text));
  margin: 0;
}

.meta-top-campaign-metric-value-green {
  color: hsl(var(--workspace-color-3));
}

/* ============================================
   Meta Dashboard - Ad Creatives Tab
   ============================================ */

.meta-creatives-card {
  padding: 1.5rem;
  border-color: hsl(var(--dashboard-border) / 0.3);
}

.meta-creatives-header {
  margin-bottom: 1.5rem;
}

.meta-creatives-title {
  font-size: 1.125rem;
  font-weight: 600;
  color: hsl(var(--dashboard-text));
  margin: 0;
}

.meta-creatives-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1rem;
}

@media (min-width: 768px) {
  .meta-creatives-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (min-width: 1024px) {
  .meta-creatives-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

.meta-creative-card {
  padding: 1rem;
  background-color: hsl(var(--dashboard-bg));
  border: 1px solid hsl(var(--dashboard-border) / 0.3);
  border-radius: calc(var(--radius) - 2px);
  transition: all 0.3s;
}

.meta-creative-card:hover {
  border-color: hsl(var(--dashboard-accent) / 0.4);
}

.meta-creative-placeholder {
  aspect-ratio: 16 / 9;
  background-color: hsl(var(--dashboard-card));
  border: 1px solid hsl(var(--dashboard-border) / 0.3);
  border-radius: calc(var(--radius) - 2px);
  margin-bottom: 1rem;
  display: flex;
  align-items: center;
  justify-content: center;
}

.meta-creative-icon {
  width: 1rem;
  height: 1rem;
  color: hsl(var(--dashboard-accent));
}

.meta-creative-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 0.5rem;
}

.meta-creative-name {
  font-size: 0.875rem;
  font-weight: 500;
  color: hsl(var(--dashboard-text));
  margin: 0;
}

.meta-creative-type-badge {
  display: inline-flex;
  align-items: center;
  padding: 0.125rem 0.5rem;
  border-radius: calc(var(--radius) - 4px);
  font-size: 0.75rem;
  font-weight: 500;
  border: 1px solid hsl(var(--dashboard-accent) / 0.5);
  color: hsl(var(--dashboard-accent));
  text-transform: capitalize;
}

.meta-creative-metrics {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.5rem;
  margin-top: 1rem;
}

.meta-creative-metric {
  display: flex;
  flex-direction: column;
}

.meta-creative-metric-label {
  font-size: 0.75rem;
  color: hsl(var(--dashboard-text-muted));
  margin: 0 0 0.25rem 0;
}

.meta-creative-metric-value {
  font-size: 0.875rem;
  font-weight: 500;
  color: hsl(var(--dashboard-text));
  margin: 0;
}

.meta-creative-metric-value-green {
  color: hsl(142 71% 45%);
}

/* ============================================
   Meta Dashboard - Placements Tab
   ============================================ */

.meta-placements-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.5rem;
}

@media (min-width: 1024px) {
  .meta-placements-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

.meta-placements-chart-card,
.meta-placements-breakdown-card {
  padding: 1.5rem;
  border-color: hsl(var(--dashboard-border) / 0.3);
}

.meta-placements-chart-header,
.meta-placements-breakdown-header {
  margin-bottom: 1rem;
}

.meta-placements-chart-title,
.meta-placements-breakdown-title {
  font-size: 1.125rem;
  font-weight: 600;
  color: hsl(var(--dashboard-text));
  margin: 0;
}

.meta-placements-chart-container {
  position: relative;
  width: 100%;
  height: 300px;
}

.meta-placements-breakdown-list {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.meta-placement-item {
  padding: 1rem;
  background-color: hsl(var(--dashboard-bg));
  border: 1px solid hsl(var(--dashboard-border) / 0.3);
  border-radius: calc(var(--radius) - 2px);
}

.meta-placement-item-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 0.5rem;
}

.meta-placement-item-name {
  font-size: 0.875rem;
  font-weight: 500;
  color: hsl(var(--dashboard-text));
  margin: 0;
}

.meta-placement-item-ctr {
  font-size: 0.875rem;
  font-weight: 500;
  color: hsl(var(--dashboard-accent));
}

.meta-placement-item-metrics {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1rem;
}

.meta-placement-item-metric {
  display: flex;
  flex-direction: column;
}

.meta-placement-item-metric-label {
  font-size: 0.75rem;
  color: hsl(var(--dashboard-text-muted));
  margin: 0 0 0.25rem 0;
}

.meta-placement-item-metric-value {
  font-size: 0.875rem;
  font-weight: 500;
  color: hsl(var(--dashboard-text));
  margin: 0;
}

/* ============================================
   TikTok Dashboard Styles
   ============================================ */

.tiktok-dashboard-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 2rem;
  flex-wrap: wrap;
  gap: 1rem;
}

.tiktok-dashboard-header-left {
  display: flex;
  align-items: center;
  gap: 1rem;
  flex-wrap: wrap;
}

.tiktok-back-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  color: hsl(var(--dashboard-text-muted));
  text-decoration: none;
  transition: color 0.2s;
}

.tiktok-back-btn:hover {
  color: hsl(var(--dashboard-text));
}

.tiktok-dashboard-title-group {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.tiktok-dashboard-logo {
  display: flex;
  align-items: center;
  justify-content: center;
}

.tiktok-logo-circle {
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 50%;
  background-color: hsl(0 0% 100%);
  color: hsl(0 0% 0%);
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 1.125rem;
}

.google-logo-circle {
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 50%;
  background-color: hsl(142 71% 50%);
  color: hsl(0 0% 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 1.125rem;
}

.tiktok-dashboard-title {
  font-size: 1.5rem;
  font-weight: 700;
  color: hsl(var(--dashboard-text));
  margin: 0;
}

.tiktok-dashboard-header-right {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  flex-wrap: nowrap;
  min-width: 0;
}

.tiktok-header-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
}

.tiktok-kpi-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1rem;
  margin-bottom: 2rem;
}

@media (min-width: 768px) {
  .tiktok-kpi-grid {
    grid-template-columns: repeat(5, 1fr);
  }
}

.tiktok-kpi-card {
  border: 1px solid hsl(var(--dashboard-border) / 0.3);
  padding: 1rem;
  transition: all 0.3s;
  position: relative;
}

.tiktok-kpi-card:hover {
  border-color: hsl(var(--dashboard-accent) / 0.6);
  box-shadow: 0 10px 15px -3px hsl(var(--dashboard-accent) / 0.1), 0 4px 6px -2px hsl(var(--dashboard-accent) / 0.1);
}

.tiktok-kpi-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 0.5rem;
}

.tiktok-kpi-icon {
  color: hsl(var(--dashboard-accent));
  flex-shrink: 0;
}

.tiktok-kpi-change {
  font-size: 0.75rem;
  font-weight: 600;
}

.tiktok-kpi-positive {
  color: hsl(142 71% 45%);
}

.tiktok-kpi-negative {
  color: hsl(0 84% 60%);
}

.tiktok-kpi-value {
  font-size: 1.5rem;
  font-weight: 700;
  color: hsl(var(--dashboard-text));
  margin: 0 0 0.25rem 0;
  line-height: 1;
}

.tiktok-kpi-label {
  font-size: 0.875rem;
  color: hsl(var(--dashboard-text-muted));
  margin: 0;
  display: flex;
  align-items: center;
  gap: 0.375rem;
}

.tiktok-kpi-label-text {
  flex: 1;
}



/* ============================================
   Module: tiktok-dashboard.css
   ============================================ */

/* TikTok KPI Loading Skeleton */
.tiktok-kpi-loading-skeleton {
  position: relative;
  color: hsl(var(--dashboard-text-muted));
  overflow: hidden;
}

.tiktok-kpi-loading-skeleton::after {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(
    90deg,
    transparent,
    hsl(var(--dashboard-accent) / 0.1),
    transparent
  );
  animation: tiktok-kpi-skeleton-loading 1.5s infinite;
}

@keyframes tiktok-kpi-skeleton-loading {
  0% {
    left: -100%;
  }
  100% {
    left: 100%;
  }
}

.tiktok-kpi-loading {
  display: inline-block;
  width: 2rem;
  height: 0.75rem;
  background-color: hsl(var(--dashboard-text-muted) / 0.3);
  border-radius: 0.25rem;
  position: relative;
  overflow: hidden;
}

.tiktok-kpi-loading::after {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(
    90deg,
    transparent,
    hsl(var(--dashboard-accent) / 0.2),
    transparent
  );
  animation: tiktok-kpi-skeleton-loading 1.5s infinite;
}

/* TikTok Advertiser Selector - Uses generic account-selector classes */

/* TikTok uses generic account-selector and date-range classes */

.tiktok-tabs-wrapper {
  margin-top: 2rem;
}

.tiktok-charts-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.5rem;
  box-sizing: border-box;
  max-width: 100%;
}

@media (min-width: 1024px) {
  .tiktok-charts-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

.tiktok-chart-card {
  padding: 1.5rem;
  border-color: hsl(var(--dashboard-border) / 0.3);
  box-sizing: border-box;
  max-width: 100%;
  min-width: 0;
}

.tiktok-chart-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 1rem;
}

.tiktok-chart-title {
  font-size: 1.125rem;
  font-weight: 600;
  color: hsl(var(--dashboard-text));
  margin: 0 0 1rem 0;
}

.tiktok-chart-placeholder {
  min-height: 300px;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: hsl(var(--dashboard-bg));
  border-radius: calc(var(--radius) - 2px);
  padding: 2rem;
}

.tiktok-chart-container {
  position: relative;
  width: 100%;
  height: 300px;
  margin-top: 1rem;
  box-sizing: border-box;
  max-width: 100%;
  min-width: 0;
}

.tiktok-chart-container canvas {
  max-height: 100%;
}

/* TikTok uses shared .chart-type-switcher classes - no platform-specific classes needed */

.tiktok-campaign-list {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.tiktok-campaign-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1rem;
  background-color: hsl(var(--dashboard-bg));
  border: 1px solid hsl(var(--dashboard-border) / 0.3);
  border-radius: calc(var(--radius) - 2px);
  transition: all 0.2s;
}

.tiktok-campaign-item:hover {
  border-color: hsl(var(--dashboard-accent) / 0.4);
}

.tiktok-campaign-item-left {
  display: flex;
  align-items: center;
  gap: 1rem;
}

.tiktok-campaign-name {
  font-weight: 500;
  color: hsl(var(--dashboard-text));
  margin: 0 0 0.25rem 0;
}

.tiktok-campaign-meta {
  font-size: 0.875rem;
  color: hsl(var(--dashboard-text-muted));
  margin: 0;
}

.tiktok-campaign-item-right {
  display: flex;
  align-items: center;
  gap: 2rem;
}

.tiktok-campaign-stat {
  text-align: right;
}

.tiktok-campaign-stat-label {
  font-size: 0.875rem;
  color: hsl(var(--dashboard-text-muted));
  margin: 0 0 0.25rem 0;
}

.tiktok-campaign-stat-value {
  font-weight: 500;
  color: hsl(var(--dashboard-text));
  margin: 0;
}

.tiktok-campaigns-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1.5rem;
  flex-wrap: wrap;
}

.tiktok-campaigns-search-wrapper {
  position: relative;
  flex: 1;
  min-width: 200px;
}

.tiktok-search-icon {
  position: absolute;
  left: 0.75rem;
  top: 50%;
  transform: translateY(-50%);
  width: 1rem;
  height: 1rem;
  color: hsl(var(--dashboard-text-muted));
  pointer-events: none;
  z-index: 1;
}

.tiktok-table-wrapper {
  overflow-x: auto;
}

.tiktok-table {
  width: 100%;
  border-collapse: collapse;
}

.tiktok-table thead {
  border-bottom: 1px solid hsl(var(--dashboard-border) / 0.3);
}

.tiktok-table th {
  text-align: left;
  padding: 0.75rem 1rem;
  font-size: 0.875rem;
  font-weight: 500;
  color: hsl(var(--dashboard-text-muted));
}

.tiktok-table th.text-right {
  text-align: right;
}

.tiktok-table th.text-center {
  text-align: center;
}

.tiktok-table tbody tr {
  border-bottom: 1px solid hsl(var(--dashboard-border) / 0.2);
  transition: background-color 0.2s;
}

.tiktok-table tbody tr:hover {
  background-color: hsl(var(--dashboard-bg) / 0.5);
}

.tiktok-table td {
  padding: 1rem;
}

.tiktok-table-campaign-name {
  font-weight: 500;
  color: hsl(var(--dashboard-text));
  margin: 0;
}

.tiktok-table-actions {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
}

.tiktok-video-list {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.tiktok-video-item {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 1rem;
  background-color: hsl(var(--dashboard-bg));
  border: 1px solid hsl(var(--dashboard-border) / 0.3);
  border-radius: calc(var(--radius) - 2px);
  transition: all 0.2s;
}

.tiktok-video-item:hover {
  border-color: hsl(var(--dashboard-accent) / 0.4);
}

.tiktok-video-thumbnail {
  width: 12rem;
  height: 9rem;
  background-color: hsl(var(--dashboard-card));
  border: 1px solid hsl(var(--dashboard-border) / 0.3);
  border-radius: calc(var(--radius) - 2px);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.tiktok-video-content {
  flex: 1;
}

.tiktok-video-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 0.5rem;
}

.tiktok-video-name {
  font-weight: 500;
  color: hsl(var(--dashboard-text));
  margin: 0 0 0.25rem 0;
}

.tiktok-video-meta {
  font-size: 0.875rem;
  color: hsl(var(--dashboard-text-muted));
  margin: 0;
}

.tiktok-video-stats {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 1rem;
  font-size: 0.875rem;
}

.tiktok-video-stat {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.tiktok-hashtag-list,
.tiktok-sound-list {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.tiktok-hashtag-item,
.tiktok-sound-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.75rem;
  background-color: hsl(var(--dashboard-bg));
  border: 1px solid hsl(var(--dashboard-border) / 0.3);
  border-radius: calc(var(--radius) - 2px);
  transition: all 0.2s;
}

.tiktok-hashtag-item:hover,
.tiktok-sound-item:hover {
  border-color: hsl(var(--dashboard-accent) / 0.4);
}

.tiktok-hashtag-tag {
  font-weight: 500;
  color: hsl(var(--dashboard-accent));
  margin: 0 0 0.25rem 0;
}

.tiktok-hashtag-meta {
  font-size: 0.875rem;
  color: hsl(var(--dashboard-text-muted));
  margin: 0;
}

.tiktok-hashtag-stats {
  display: flex;
  align-items: center;
  gap: 1rem;
}

.tiktok-hashtag-used {
  font-size: 0.875rem;
  color: hsl(var(--dashboard-text-muted));
}

.tiktok-hashtag-performance {
  font-size: 0.875rem;
  font-weight: 500;
}

.tiktok-sound-item-left {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.tiktok-sound-icon {
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 50%;
  background-color: hsl(var(--dashboard-card));
  border: 1px solid hsl(var(--dashboard-accent) / 0.3);
  display: flex;
  align-items: center;
  justify-content: center;
}

.tiktok-sound-name {
  font-weight: 500;
  color: hsl(var(--dashboard-text));
  margin: 0 0 0.25rem 0;
}

.tiktok-sound-meta {
  font-size: 0.875rem;
  color: hsl(var(--dashboard-text-muted));
  margin: 0;
}

.tiktok-sound-item-right {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.tiktok-recommendations-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1rem;
}

@media (min-width: 768px) {
  .tiktok-recommendations-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

.tiktok-recommendation-item {
  padding: 1rem;
  background-color: hsl(var(--dashboard-bg));
  border: 1px solid hsl(var(--dashboard-border) / 0.3);
  border-radius: calc(var(--radius) - 2px);
}

.tiktok-recommendation-title {
  font-weight: 500;
  color: hsl(var(--dashboard-text));
  margin: 0 0 0.25rem 0;
}

.tiktok-recommendation-desc {
  font-size: 0.875rem;
  color: hsl(var(--dashboard-text-muted));
  margin: 0;
}

.tiktok-device-stat {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-height: 250px;
}

.tiktok-device-value {
  font-size: 2.25rem;
  font-weight: 700;
  color: hsl(var(--dashboard-text));
  margin: 0 0 0.5rem 0;
}

.tiktok-device-note {
  font-size: 0.875rem;
  color: hsl(var(--dashboard-text-muted));
  text-align: center;
  margin: 1rem 0 0 0;
}

.tiktok-interest-list {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.tiktok-interest-item {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.tiktok-interest-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 0.25rem;
}

.tiktok-interest-stats {
  display: flex;
  align-items: center;
  gap: 1rem;
}

.text-right {
  text-align: right;
}

.text-center {
  text-align: center;
}

.hidden {
  display: none;
}

/* Shared Dashboard Table Styles - Used by Meta, TikTok, and Google */
.dashboard-table-wrapper {
  overflow-x: auto;
}

.dashboard-table {
  width: 100%;
  border-collapse: collapse;
}

.dashboard-table thead {
  border-bottom: 1px solid hsl(var(--dashboard-border) / 0.3);
}

.dashboard-table th {
  padding: 0.75rem 1rem;
  text-align: left;
  font-weight: 500;
  font-size: 0.875rem;
  color: hsl(var(--dashboard-text-muted));
}

.dashboard-table th.text-right {
  text-align: right;
}

.dashboard-table th.text-center {
  text-align: center;
}

.dashboard-table tbody tr {
  border-bottom: 1px solid hsl(var(--dashboard-border) / 0.2);
  transition: background-color 0.2s;
}

.dashboard-table tbody tr:hover {
  background-color: hsl(var(--dashboard-bg) / 0.5);
}

.dashboard-table td {
  padding: 1rem;
}

.dashboard-table-name {
  font-weight: 500;
  color: hsl(var(--dashboard-text));
  margin: 0;
}

/* Shared Campaign Item Styles */
.dashboard-campaign-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1rem;
  background-color: hsl(var(--dashboard-bg));
  border: 1px solid hsl(var(--dashboard-border) / 0.3);
  border-radius: calc(var(--radius) - 2px);
  transition: all 0.2s;
}

.dashboard-campaign-item:hover {
  border-color: hsl(var(--dashboard-accent) / 0.4);
}

.dashboard-campaign-left {
  display: flex;
  align-items: center;
  gap: 1rem;
}

.dashboard-campaign-name {
  font-weight: 500;
  color: hsl(var(--dashboard-text));
  margin: 0 0 0.25rem 0;
}

.dashboard-campaign-stats {
  display: flex;
  align-items: center;
  gap: 2rem;
}

.dashboard-campaign-stat {
  text-align: right;
}

.dashboard-campaign-stat p:first-child {
  font-size: 0.875rem;
  color: hsl(var(--dashboard-text-muted));
  margin: 0 0 0.25rem 0;
}

.dashboard-campaign-stat p:last-child {
  font-weight: 500;
  color: hsl(var(--dashboard-text));
  margin: 0;
}

/* Shared Search Wrapper */
.dashboard-search-wrapper {
  position: relative;
  display: flex;
  align-items: center;
}

.dashboard-search-input {
  padding: 0.5rem 0.75rem 0.5rem 2.5rem;
  background-color: hsl(var(--dashboard-bg));
  border: 1px solid hsl(var(--dashboard-border) / 0.3);
  border-radius: calc(var(--radius) - 2px);
  color: hsl(var(--dashboard-text));
  font-size: 0.875rem;
  width: 16rem;
  transition: all 0.2s;
}

.dashboard-search-input:focus {
  outline: none;
  border-color: hsl(var(--dashboard-accent) / 0.5);
}

/* Shared Dashboard Header with Filters */
.dashboard-filters-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 1.5rem;
  flex-wrap: wrap;
  gap: 1rem;
}

.dashboard-filters-group {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

/* Google Dashboard Styles - Reusing shared classes where possible */


/* ============================================
   Module: google-dashboard.css
   ============================================ */

.google-network-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1rem;
}

@media (min-width: 768px) {
  .google-network-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (min-width: 1024px) {
  .google-network-grid {
    grid-template-columns: repeat(4, 1fr);
  }
}

.google-network-item {
  padding: 1rem;
  background-color: hsl(var(--dashboard-bg));
  border: 1px solid hsl(var(--dashboard-border) / 0.3);
  border-radius: calc(var(--radius) - 2px);
  transition: all 0.2s;
}

.google-network-item:hover {
  border-color: hsl(var(--dashboard-accent) / 0.4);
}

.google-network-name {
  font-weight: 500;
  color: hsl(var(--dashboard-text));
  margin: 0 0 0.75rem 0;
}

.google-network-stats {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.google-network-stat {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 0.875rem;
}

.google-campaigns-list {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.google-campaign-list {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.google-campaign-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1rem;
  background-color: hsl(var(--dashboard-bg));
  border: 1px solid hsl(var(--dashboard-border) / 0.3);
  border-radius: calc(var(--radius) - 2px);
  transition: all 0.2s;
}

.google-campaign-item:hover {
  border-color: hsl(var(--dashboard-accent) / 0.4);
}

.google-campaign-item-left {
  display: flex;
  align-items: center;
  gap: 1rem;
}

.google-campaign-name {
  font-weight: 500;
  color: hsl(var(--dashboard-text));
  margin: 0 0 0.25rem 0;
  font-size: 0.875rem;
}

.google-campaign-meta {
  font-size: 0.875rem;
  color: hsl(var(--dashboard-text-muted));
  margin: 0;
}

.google-campaign-item-right {
  display: flex;
  align-items: center;
  gap: 2rem;
}

@media (max-width: 768px) {
  .google-campaign-item {
    flex-direction: column;
    align-items: flex-start;
    gap: 1rem;
  }
  
  .google-campaign-item-right {
    width: 100%;
    justify-content: space-between;
    gap: 1rem;
  }
}

.google-campaign-stat {
  text-align: right;
}

.google-campaign-stat-label {
  font-size: 0.875rem;
  color: hsl(var(--dashboard-text-muted));
  margin: 0 0 0.25rem 0;
}

.google-campaign-stat-value {
  font-weight: 500;
  color: hsl(var(--dashboard-text));
  margin: 0;
  font-size: 0.875rem;
}

/* Google uses shared .dashboard-campaign-item, .dashboard-campaign-left, etc. */

.google-campaign-badge {
  padding: 0.125rem 0.625rem;
  border-radius: calc(var(--radius) - 2px);
  font-size: 0.75rem;
  font-weight: 500;
  border: 1px solid;
  white-space: nowrap;
}

/* Google uses shared .dashboard-filters-header, .dashboard-filters-group, .dashboard-search-wrapper, .dashboard-search-input, .dashboard-table-wrapper, .dashboard-table, .dashboard-table-name */

.google-status-badge {
  padding: 0.25rem 0.75rem;
  border-radius: calc(var(--radius) - 2px);
  font-size: 0.75rem;
  font-weight: 500;
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
}

.google-status-active {
  background-color: hsl(142 71% 50% / 0.2);
  color: hsl(142 71% 50%);
  border: 1px solid hsl(142 71% 50% / 0.5);
}

.google-status-paused {
  background-color: hsl(45 63% 49% / 0.2);
  color: hsl(45 63% 49%);
  border: 1px solid hsl(45 63% 49% / 0.5);
}

.google-action-btn {
  padding: 0.375rem;
  background-color: transparent;
  border: 1px solid hsl(var(--dashboard-border) / 0.3);
  border-radius: calc(var(--radius) - 2px);
  color: hsl(var(--dashboard-text-muted));
  cursor: pointer;
  transition: all 0.2s;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.google-action-btn:hover {
  color: hsl(var(--dashboard-accent));
  border-color: hsl(var(--dashboard-accent) / 0.5);
}

/* Google uses shared .dashboard-table-wrapper, .dashboard-table, .dashboard-table-name for keywords and locations tables */

.google-match-badge {
  padding: 0.25rem 0.75rem;
  border-radius: calc(var(--radius) - 2px);
  font-size: 0.75rem;
  font-weight: 500;
  background-color: hsl(var(--dashboard-bg));
  border: 1px solid hsl(var(--dashboard-accent) / 0.5);
  color: hsl(var(--dashboard-accent));
}

.google-search-terms-list {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.google-search-term-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.75rem;
  background-color: hsl(var(--dashboard-bg));
  border: 1px solid hsl(var(--dashboard-border) / 0.3);
  border-radius: calc(var(--radius) - 2px);
  transition: all 0.2s;
}

.google-search-term-item:hover {
  border-color: hsl(var(--dashboard-accent) / 0.4);
}

.google-search-term-text {
  color: hsl(var(--dashboard-text));
  font-weight: 500;
}

.google-search-term-actions {
  display: flex;
  align-items: center;
  gap: 1rem;
}

.google-device-list {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  margin-top: 1rem;
}

.google-device-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.75rem;
  background-color: hsl(var(--dashboard-bg));
  border-radius: calc(var(--radius) - 2px);
}

.google-device-left {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.google-device-stats {
  display: flex;
  align-items: center;
  gap: 1.5rem;
  font-size: 0.875rem;
}

.google-audience-segments-list {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.google-audience-segment-item {
  padding: 0.75rem;
  background-color: hsl(var(--dashboard-bg));
  border: 1px solid hsl(var(--dashboard-border) / 0.3);
  border-radius: calc(var(--radius) - 2px);
  transition: all 0.2s;
}

.google-audience-segment-item:hover {
  border-color: hsl(var(--dashboard-accent) / 0.4);
}

.google-audience-segment-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 0.5rem;
}

.google-audience-segment-name {
  font-weight: 500;
  color: hsl(var(--dashboard-text));
}

.google-audience-segment-stats {
  display: flex;
  align-items: center;
  gap: 1rem;
  font-size: 0.875rem;
}

.google-locations-list {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.google-location-item {
  padding: 1rem;
  background-color: hsl(var(--dashboard-bg));
  border: 1px solid hsl(var(--dashboard-border) / 0.3);
  border-radius: calc(var(--radius) - 2px);
  transition: all 0.2s;
}

.google-location-item:hover {
  border-color: hsl(var(--dashboard-accent) / 0.4);
}

.google-location-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 0.5rem;
}

.google-location-name {
  font-weight: 500;
  color: hsl(var(--dashboard-text));
}

.google-location-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.5rem;
  font-size: 0.875rem;
}

.google-location-stat {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.google-location-stat span {
  font-size: 0.875rem;
}

.google-location-stat p {
  margin: 0;
  font-weight: 500;
}

/* ============================================
   Workspace Manager Styles
   ============================================ */



/* ============================================
   Module: workspace-manager.css
   ============================================ */

/* Override page-container for workspace manager */
.workspace-manager-page.page-container {
  padding: 0;
  height: 100vh;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

.workspace-manager-content {
  display: flex;
  flex-direction: column;
  flex: 1;
  overflow: hidden;
  padding: 2rem;
  padding-right: 6rem;
  background-color: hsl(var(--dashboard-bg));
  min-height: 0;
  height: 100%;
}

.workspace-manager-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 1.5rem;
  flex-shrink: 0;
  padding-bottom: 1.5rem;
}

.workspace-manager-header-left {
  display: flex;
  align-items: center;
  gap: 1rem;
}

.workspace-manager-back-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.875rem;
  color: hsl(var(--dashboard-text-muted));
  background: transparent;
  border: none;
  padding: 0;
  cursor: pointer;
  text-decoration: none;
  transition: color 0.2s;
}

.workspace-manager-back-btn:hover {
  color: hsl(var(--dashboard-text));
}

.workspace-manager-back-btn span {
  text-decoration: none;
}

.workspace-manager-title-group {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.workspace-manager-title-icon {
  width: 1.5rem;
  height: 1.5rem;
  color: hsl(var(--dashboard-accent));
}

.workspace-manager-title {
  font-size: 1.5rem;
  font-weight: 700;
  color: hsl(var(--dashboard-text));
  margin: 0;
}

.workspace-manager-header-right {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.workspace-manager-sync-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  transition: all 0.3s;
}

.workspace-manager-sync-btn:hover {
  opacity: 0.9;
}

.workspace-manager-sync-btn:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

.workspace-manager-new-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  transition: all 0.3s;
}

.workspace-manager-new-btn:hover {
  box-shadow: 0 10px 15px -3px hsl(var(--dashboard-accent) / 0.3), 0 4px 6px -2px hsl(var(--dashboard-accent) / 0.3);
}

.workspace-manager-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.5rem;
  flex: 1;
  min-height: 0;
  overflow: hidden;
  max-width: 100%;
}

@media (min-width: 1280px) {
  .workspace-manager-grid {
    grid-template-columns: 1fr 1fr;
    max-width: 100%;
  }
}

.workspace-manager-column {
  display: flex;
  flex-direction: column;
  min-height: 0;
  overflow: hidden;
  height: 100%;
}

@media (min-width: 1280px) {
  .workspace-manager-column:last-child {
    overflow: visible;
    padding-right: 0;
  }
}

.workspace-manager-section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 1rem;
  flex-shrink: 0;
}

.workspace-manager-section-header-left {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.workspace-manager-section-icon {
  width: 1.25rem;
  height: 1.25rem;
  color: hsl(var(--dashboard-accent));
}

.workspace-manager-section-title {
  font-size: 1.125rem;
  font-weight: 600;
  color: hsl(var(--dashboard-text));
  margin: 0;
}

.workspace-manager-section-header-right {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.workspace-manager-expand-all-btn {
  height: 2rem;
  width: 2rem;
  padding: 0;
  color: hsl(var(--dashboard-text-muted));
  transition: color 0.2s, transform 0.2s;
}

.workspace-manager-expand-all-btn:hover {
  color: hsl(var(--dashboard-text));
}

.workspace-manager-expand-all-icon {
  width: 1rem;
  height: 1rem;
  transition: transform 0.2s;
}

.workspace-manager-search-wrapper {
  position: relative;
  display: flex;
  align-items: center;
}

.workspace-manager-search-icon {
  position: absolute;
  left: 0.625rem;
  width: 0.875rem;
  height: 0.875rem;
  color: hsl(var(--dashboard-text-muted));
  pointer-events: none;
}

.workspace-manager-search-input {
  padding-left: 2rem;
  height: 2rem;
  width: 10rem;
  background-color: hsl(var(--dashboard-bg));
  border-color: hsl(var(--dashboard-border) / 0.3);
  color: hsl(var(--dashboard-text));
  font-size: 0.875rem;
}

.workspace-manager-workspace-card[data-search-hidden="true"] {
  display: none;
}

.workspace-manager-search-input::placeholder {
  color: hsl(var(--dashboard-text-muted));
}

.workspace-manager-view-toggle {
  height: 2rem;
  width: 2rem;
  padding: 0;
}

.workspace-manager-view-toggle.active {
  background-color: hsl(var(--dashboard-accent) / 0.2);
  color: hsl(var(--dashboard-accent));
}

.workspace-manager-scroll-area {
  flex: 1;
  min-height: 0;
  overflow-y: auto;
  overflow-x: visible;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: thin;
  scrollbar-color: hsl(var(--dashboard-border) / 0.3) transparent;
}

.workspace-manager-scroll-area::-webkit-scrollbar {
  width: 8px;
}

.workspace-manager-scroll-area::-webkit-scrollbar-track {
  background: transparent;
}

.workspace-manager-scroll-area::-webkit-scrollbar-thumb {
  background-color: hsl(var(--dashboard-border) / 0.3);
  border-radius: 4px;
}

.workspace-manager-scroll-area::-webkit-scrollbar-thumb:hover {
  background-color: hsl(var(--dashboard-border) / 0.5);
}

.workspace-manager-platforms-list {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  padding-right: 1rem;
}

.workspace-manager-platform-card {
  background-color: hsl(var(--dashboard-card));
  border-color: hsl(var(--dashboard-border) / 0.3);
  overflow: hidden;
}

.workspace-manager-platform-header {
  padding: 1rem;
  border-left: 4px solid;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.workspace-manager-platform-border-meta {
  border-left-color: hsl(var(--platform-meta));
}

.workspace-manager-platform-border-google {
  border-left-color: hsl(var(--platform-google));
}

.workspace-manager-platform-border-tiktok {
  border-left-color: hsl(var(--platform-tiktok));
}

.workspace-manager-platform-border-pinterest {
  border-left-color: hsl(var(--platform-pinterest));
}

.workspace-manager-platform-border-x {
  border-left-color: hsl(var(--platform-x));
}

.workspace-manager-platform-header-left {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.workspace-manager-platform-logo {
  width: 2.5rem;
  height: 2.5rem;
  border-radius: calc(var(--radius) - 2px);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  background-color: hsl(var(--dashboard-bg));
  flex-shrink: 0;
}

.workspace-manager-platform-logo-img {
  width: 1.75rem;
  height: 1.75rem;
  object-fit: contain;
}

.workspace-manager-platform-name {
  font-size: 1.125rem;
  font-weight: 600;
  color: hsl(var(--dashboard-text));
  margin: 0;
}

.workspace-manager-platform-business {
  display: flex;
  align-items: center;
  gap: 0.25rem;
  margin-top: 0.125rem;
}

.workspace-manager-platform-business svg {
  width: 0.75rem;
  height: 0.75rem;
  color: hsl(var(--dashboard-text-muted));
}

.workspace-manager-platform-business span {
  font-size: 0.75rem;
  color: hsl(var(--dashboard-text-muted));
}

.workspace-manager-platform-header-right {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.workspace-manager-platform-toggle {
  height: 2rem;
  width: 2rem;
  padding: 0;
  color: hsl(var(--dashboard-text-muted));
  flex-shrink: 0;
}

.workspace-manager-platform-toggle:hover {
  color: hsl(var(--dashboard-text));
}

.workspace-manager-chevron {
  width: 1rem;
  height: 1rem;
}

.workspace-manager-chevron-down {
  display: block;
}

.workspace-manager-chevron-right {
  display: none;
}

.workspace-manager-platform-toggle[data-expanded="false"] .workspace-manager-chevron-down,
.workspace-manager-workspace-toggle[data-expanded="false"] .workspace-manager-chevron-down {
  display: none;
}

.workspace-manager-platform-toggle[data-expanded="false"] .workspace-manager-chevron-right,
.workspace-manager-workspace-toggle[data-expanded="false"] .workspace-manager-chevron-right {
  display: block;
}

.workspace-manager-platform-toggle[data-expanded="true"] .workspace-manager-chevron-down,
.workspace-manager-workspace-toggle[data-expanded="true"] .workspace-manager-chevron-down {
  display: block;
}

.workspace-manager-platform-toggle[data-expanded="true"] .workspace-manager-chevron-right,
.workspace-manager-workspace-toggle[data-expanded="true"] .workspace-manager-chevron-right {
  display: none;
}

.workspace-manager-platform-connect {
  height: 2rem;
  font-size: 0.875rem;
  padding: 0 0.75rem;
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
}

.workspace-manager-platform-accounts {
  border-top: 1px solid hsl(var(--dashboard-border) / 0.3);
  padding: 0.75rem;
  background-color: hsl(var(--dashboard-bg) / 0.5);
  display: none;
}

.workspace-manager-platform-accounts[data-expanded="true"] {
  display: block;
}

.workspace-manager-platform-accounts-header {
  display: flex;
  align-items: center;
  margin-bottom: 0.5rem;
}

.workspace-manager-platform-accounts-label {
  font-size: 0.75rem;
  font-weight: 600;
  color: hsl(var(--dashboard-text-muted));
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.workspace-manager-platform-disconnect {
  height: 1.5rem;
  font-size: 0.75rem;
  padding: 0 0.5rem;
  color: hsl(0 84% 60%);
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
}

.workspace-manager-platform-disconnect:hover {
  background-color: hsl(0 84% 60% / 0.1);
  color: hsl(0 84% 60%);
}

.workspace-manager-accounts-list {
  display: flex;
  flex-direction: column;
  gap: 0.375rem;
  transition: background-color 0.2s, border-color 0.2s;
}

.workspace-manager-accounts-list.workspace-manager-drag-over {
  background-color: hsl(var(--dashboard-accent) / 0.05);
  border-radius: calc(var(--radius) - 2px);
  border: 2px dashed hsl(var(--dashboard-accent) / 0.5);
  padding: 0.5rem;
  min-height: 3rem;
}

.workspace-manager-platform-accounts-empty {
  color: hsl(var(--dashboard-text-muted));
  font-size: 0.875rem;
  font-style: italic;
  padding: 0.5rem 0;
}

.workspace-manager-account-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-radius: calc(var(--radius) - 2px);
  padding: 0.5rem 0.75rem;
  background-color: hsl(var(--dashboard-card));
  border: 1px solid hsl(var(--dashboard-border) / 0.3);
  cursor: grab;
}

.workspace-manager-account-item:active {
  cursor: grabbing;
}

.workspace-manager-account-item:hover {
  border-color: hsl(var(--dashboard-accent) / 0.5);
}

.workspace-manager-account-assigned {
  background-color: hsl(var(--dashboard-card) / 0.5);
  border-color: hsl(var(--dashboard-border) / 0.2);
  opacity: 0.6;
  cursor: default;
}

.workspace-manager-account-assigned:hover {
  border-color: hsl(var(--dashboard-border) / 0.2);
}

.workspace-manager-account-item span {
  font-size: 0.875rem;
  color: hsl(var(--dashboard-text));
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.workspace-manager-account-left {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  min-width: 0;
}

.workspace-manager-drag-handle {
  width: 0.75rem;
  height: 0.75rem;
  color: hsl(var(--dashboard-text-muted));
  flex-shrink: 0;
}

.workspace-manager-account-right {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-shrink: 0;
}

.badge-outline.badge-status-active {
  border-color: hsl(142 71% 45% / 0.3);
  color: hsl(142 71% 45%);
}

.badge-outline.badge-status-paused {
  border-color: hsl(45 93% 47% / 0.3);
  color: hsl(45 93% 47%);
}

.badge-outline.badge-status-disconnected {
  border-color: hsl(0 84% 60% / 0.3);
  color: hsl(0 84% 60%);
}

.badge-outline.badge-assigned {
  border-color: hsl(var(--dashboard-accent) / 0.5);
  color: hsl(var(--dashboard-accent));
}

.workspace-manager-workspaces-list {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  padding-right: 1rem;
}

.workspace-manager-workspace-card {
  background-color: hsl(var(--dashboard-card));
  border-color: hsl(var(--dashboard-border) / 0.3);
  overflow: visible;
  will-change: border-color, background-color, box-shadow;
  max-width: 100%;
}

.workspace-manager-workspace-header-right {
  overflow: visible;
}

.workspace-manager-workspace-card:hover {
  border-color: hsl(var(--dashboard-accent) / 0.4);
}

.workspace-manager-workspace-card.workspace-manager-drag-over {
  border-color: hsl(var(--dashboard-accent));
  background-color: hsl(var(--dashboard-accent) / 0.05);
  box-shadow: 0 0 0 2px hsl(var(--dashboard-accent) / 0.2);
}

.workspace-manager-workspace-header {
  padding: 1rem;
  border-left: 4px solid;
  display: flex;
  align-items: center;
  justify-content: space-between;
  overflow: visible;
  position: relative;
  max-width: 100%;
}

.workspace-manager-workspace-header-left {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.workspace-manager-workspace-header-right {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-shrink: 0;
  overflow: visible;
}

.workspace-manager-workspace-toggle {
  height: 2rem;
  width: 2rem;
  padding: 0;
  color: hsl(var(--dashboard-text-muted));
  flex-shrink: 0;
}

.workspace-manager-workspace-toggle:hover {
  color: hsl(var(--dashboard-text));
}

.workspace-manager-workspace-account-count {
  min-width: 5.625rem;
  justify-content: center;
  border-color: hsl(var(--dashboard-border));
  color: hsl(var(--dashboard-text-muted));
}

.workspace-manager-workspace-avatar {
  width: 2.5rem;
  height: 2.5rem;
  border-radius: calc(var(--radius) - 2px);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  flex-shrink: 0;
}

.workspace-manager-workspace-avatar span {
  font-size: 1.125rem;
  font-weight: 700;
}

.workspace-manager-workspace-avatar-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.workspace-manager-workspace-name {
  font-size: 1.125rem;
  font-weight: 600;
  color: hsl(var(--dashboard-text));
  margin: 0;
}

.workspace-manager-workspace-date {
  font-size: 0.75rem;
  color: hsl(var(--dashboard-text-muted));
  margin: 0;
}

.workspace-manager-workspace-dropdown {
  position: relative;
  overflow: visible;
  z-index: 1001;
}

.workspace-manager-workspace-menu {
  height: 2rem;
  width: 2rem;
  padding: 0;
  color: hsl(var(--dashboard-text-muted));
}

.workspace-manager-workspace-menu:hover {
  color: hsl(var(--dashboard-text));
}

.workspace-manager-dropdown-menu {
  position: absolute;
  top: 100%;
  right: 0;
  margin-top: 0.25rem;
  background-color: hsl(var(--dashboard-card));
  border: 1px solid hsl(var(--dashboard-border));
  border-radius: calc(var(--radius) - 2px);
  box-shadow: 0 10px 15px -3px hsl(var(--a11y-shadow) / 0.1), 0 4px 6px -2px hsl(var(--a11y-shadow) / 0.05);
  min-width: 10rem;
  z-index: 1002;
  display: none;
  overflow: visible;
}

.workspace-manager-dropdown-menu.show {
  display: block;
}

.workspace-manager-dropdown-item {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  width: 100%;
  padding: 0.5rem 0.75rem;
  font-size: 0.875rem;
  color: hsl(var(--dashboard-text));
  background: none;
  border: none;
  cursor: pointer;
  text-align: left;
  transition: background-color 0.2s;
}

.workspace-manager-dropdown-item:hover {
  background-color: hsl(var(--dashboard-accent) / 0.1);
}

.workspace-manager-dropdown-item-danger {
  color: hsl(0 84% 60%);
}

.workspace-manager-dropdown-item-danger:hover {
  background-color: hsl(0 84% 60% / 0.1);
}

.workspace-manager-dropdown-item svg {
  width: 1rem;
  height: 1rem;
}

.workspace-manager-workspace-section {
  padding: 1rem;
  border-bottom: 1px solid hsl(var(--dashboard-border) / 0.3);
}

.workspace-manager-workspace-section:last-child {
  border-bottom: none;
}

.workspace-manager-workspace-section-title {
  font-size: 0.75rem;
  font-weight: 600;
  color: hsl(var(--dashboard-text-muted));
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin: 0 0 0.75rem 0;
}

.workspace-manager-workspace-accounts-section {
  padding: 1rem;
  border-top: 1px solid hsl(var(--dashboard-border) / 0.3);
  display: none;
  overflow: hidden;
  border-bottom-left-radius: calc(var(--radius));
  border-bottom-right-radius: calc(var(--radius));
}

.workspace-manager-workspace-accounts-section[data-expanded="true"] {
  display: block;
}

.workspace-manager-workspace-section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 0.75rem;
}

.workspace-manager-workspace-section-header .workspace-manager-workspace-section-title {
  margin: 0;
}

.workspace-manager-clear-all-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  padding: 0.375rem 0.75rem;
  font-size: 0.75rem;
  color: hsl(var(--dashboard-text-muted));
  background-color: transparent;
  border: 1px solid hsl(var(--dashboard-border) / 0.3);
  border-radius: calc(var(--radius) - 2px);
  transition: all 0.2s;
  cursor: pointer;
}

.workspace-manager-clear-all-btn:hover {
  color: hsl(0 84% 60%);
  border-color: hsl(0 84% 60% / 0.5);
  background-color: hsl(0 84% 60% / 0.05);
}

.workspace-manager-clear-all-btn svg {
  width: 0.875rem;
  height: 0.875rem;
}

.workspace-manager-workspace-accounts-section .workspace-manager-workspace-section-title {
  margin-bottom: 0.75rem;
}

.workspace-manager-workspace-accounts {
  display: flex;
  flex-direction: column;
  gap: 0.375rem;
  min-height: 3.75rem;
}

.workspace-manager-workspace-accounts-empty {
  border: 2px dashed hsl(var(--dashboard-border) / 0.5);
  border-radius: calc(var(--radius) - 2px);
  padding: 1rem;
  text-align: center;
}

.workspace-manager-workspace-accounts-empty p {
  font-size: 0.875rem;
  color: hsl(var(--dashboard-text-muted));
  margin: 0;
}

.workspace-manager-workspace-account-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  background-color: hsl(var(--dashboard-bg));
  border: 1px solid hsl(var(--dashboard-border) / 0.5);
  border-radius: calc(var(--radius) - 2px);
  padding: 0.5rem 0.75rem;
  cursor: grab;
}

.workspace-manager-workspace-account-item:active {
  cursor: grabbing;
}

.workspace-manager-workspace-account-item:hover {
  border-color: hsl(var(--dashboard-accent) / 0.3);
}

.workspace-manager-workspace-account-left {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  min-width: 0;
}

.workspace-manager-workspace-account-icon {
  width: 1rem;
  height: 1rem;
  flex-shrink: 0;
  object-fit: contain;
}

.workspace-manager-workspace-account-item span {
  font-size: 0.875rem;
  color: hsl(var(--dashboard-text));
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.workspace-manager-workspace-account-remove {
  height: 1.5rem;
  width: 1.5rem;
  padding: 0;
  color: hsl(var(--dashboard-text-muted));
}

.workspace-manager-workspace-account-remove:hover {
  color: hsl(0 84% 60%);
}

.workspace-manager-workspace-members {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.workspace-manager-workspace-members-empty {
  font-size: 0.875rem;
  color: hsl(var(--dashboard-text-muted));
  font-style: italic;
  margin: 0;
}

.workspace-manager-workspace-member-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  background-color: hsl(var(--dashboard-bg));
  border: 1px solid hsl(var(--dashboard-border) / 0.5);
  border-radius: calc(var(--radius) - 2px);
  padding: 0.5rem 0.75rem;
}

.workspace-manager-workspace-member-left {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  min-width: 0;
}

.workspace-manager-workspace-member-avatar {
  width: 1.75rem;
  height: 1.75rem;
  border-radius: 50%;
  background-color: hsl(var(--dashboard-accent) / 0.2);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.workspace-manager-workspace-member-avatar span {
  font-size: 0.75rem;
  font-weight: 600;
  color: hsl(var(--dashboard-accent));
}

.workspace-manager-workspace-member-name {
  font-size: 0.875rem;
  color: hsl(var(--dashboard-text));
  margin: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.workspace-manager-workspace-member-email {
  font-size: 0.75rem;
  color: hsl(var(--dashboard-text-muted));
  margin: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.workspace-manager-workspace-member-right {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.badge-role-admin {
  border-color: hsl(0 84% 60% / 0.3);
  color: hsl(0 84% 60%);
  background-color: hsl(0 84% 60% / 0.2);
}

.badge-role-editor {
  border-color: hsl(217 91% 60% / 0.3);
  color: hsl(217 91% 60%);
  background-color: hsl(217 91% 60% / 0.2);
}

.badge-role-viewer {
  border-color: hsl(var(--dashboard-text-muted) / 0.3);
  color: hsl(var(--dashboard-text-muted));
  background-color: hsl(var(--dashboard-text-muted) / 0.2);
}

.badge-manager {
  border-color: hsl(var(--primary) / 0.5);
  color: hsl(var(--primary));
  background-color: hsl(var(--primary) / 0.2);
}

.badge-role-editor.card,
.badge-info.card {
  border-color: hsl(217 91% 60% / 0.3);
  background-color: hsl(217 91% 60% / 0.1);
}

.badge-role-editor.card .card-content p,
.badge-role-editor.card svg,
.badge-info.card .card-content p,
.badge-info.card svg {
  color: hsl(217 91% 60%);
}

.workspace-manager-workspace-member-remove {
  height: 1.5rem;
  width: 1.5rem;
  padding: 0;
  color: hsl(var(--dashboard-text-muted));
}

.workspace-manager-workspace-member-remove:hover {
  color: hsl(0 84% 60%);
}

/* Dialog Styles for Workspace Manager */
.workspace-manager-dialog-field {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  margin-bottom: 0;
}

.workspace-manager-dialog-label {
  font-size: 0.875rem;
  color: hsl(var(--dashboard-text));
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.workspace-manager-dialog-label svg {
  width: 1rem;
  height: 1rem;
}

.workspace-manager-dialog-colors {
  display: flex;
  gap: 0.5rem;
}

.workspace-manager-dialog-color {
  width: 2rem;
  height: 2rem;
  border-radius: calc(var(--radius) - 2px);
  border: none;
  cursor: pointer;
  transition: all 0.2s;
  position: relative;
}

.workspace-manager-dialog-color:hover {
  transform: scale(1.1);
}

.workspace-manager-dialog-color.selected {
  outline: 2px solid hsl(var(--dashboard-accent));
  outline-offset: 2px;
}

.workspace-manager-dialog-logo-options {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.workspace-manager-dialog-logo-upload-btn {
  margin-bottom: 0.5rem;
}

.workspace-manager-dialog-logo-divider {
  margin: 0.5rem 0;
  text-align: center;
  color: hsl(var(--dashboard-text-muted));
  font-size: 0.875rem;
}

.workspace-manager-dialog-logo-preview {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-top: 0.5rem;
}

.workspace-manager-dialog-logo-preview-img {
  width: 2.5rem;
  height: 2.5rem;
  border-radius: calc(var(--radius) - 2px);
  overflow: hidden;
  border: 1px solid hsl(var(--dashboard-border));
}

.workspace-manager-dialog-logo-preview-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.workspace-manager-dialog-logo-preview span {
  font-size: 0.75rem;
  color: hsl(var(--dashboard-text-muted));
}

/* View Mode Styles */
.workspace-manager-view-grid-mode {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1rem;
}

.workspace-manager-view-list-mode {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

/* Workspace Color Classes */
.workspace-color-1 {
  --workspace-color: var(--workspace-color-1);
}

.workspace-color-2 {
  --workspace-color: var(--workspace-color-2);
}

.workspace-color-3 {
  --workspace-color: var(--workspace-color-3);
}

.workspace-color-4 {
  --workspace-color: var(--workspace-color-4);
}

.workspace-color-5 {
  --workspace-color: var(--workspace-color-5);
}

.workspace-color-6 {
  --workspace-color: var(--workspace-color-6);
}

.workspace-color-7 {
  --workspace-color: var(--workspace-color-7);
}

.workspace-color-8 {
  --workspace-color: var(--workspace-color-8);
}

.workspace-manager-workspace-header[data-workspace-color] {
  border-left-color: hsl(var(--workspace-color));
}

.workspace-manager-workspace-avatar[data-workspace-color] {
  background-color: hsl(var(--workspace-color) / 0.2);
}

.workspace-manager-workspace-avatar[data-workspace-color] span {
  color: hsl(var(--workspace-color));
}

.workspace-manager-dialog-color[data-color-index="1"] {
  background-color: hsl(var(--workspace-color-1));
}

.workspace-manager-dialog-color[data-color-index="2"] {
  background-color: hsl(var(--workspace-color-2));
}

.workspace-manager-dialog-color[data-color-index="3"] {
  background-color: hsl(var(--workspace-color-3));
}

.workspace-manager-dialog-color[data-color-index="4"] {
  background-color: hsl(var(--workspace-color-4));
}

.workspace-manager-dialog-color[data-color-index="5"] {
  background-color: hsl(var(--workspace-color-5));
}

.workspace-manager-dialog-color[data-color-index="6"] {
  background-color: hsl(var(--workspace-color-6));
}

.workspace-manager-dialog-color[data-color-index="7"] {
  background-color: hsl(var(--workspace-color-7));
}

.workspace-manager-dialog-color[data-color-index="8"] {
  background-color: hsl(var(--workspace-color-8));
}

/* Hidden class for dialogs */
.dialog-hidden {
  display: none;
}

/* Empty state */
.workspace-manager-empty-state {
  text-align: center;
  padding: 3rem 1rem;
}

.workspace-manager-empty-state-text {
  color: hsl(var(--dashboard-text-muted));
  font-size: 0.875rem;
  margin: 0;
}

/* ============================================
   Floating Buttons Container
   ============================================ */

.floating-buttons-container {
  position: fixed;
  right: 1.5rem;
  bottom: 1.5rem;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  z-index: 50;
}

/* ============================================
   Accessibility Widget
   ============================================ */

.accessibility-widget {
  position: relative;
}

.accessibility-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 3rem;
  height: 3rem;
  padding: 0;
  border-radius: 9999px;
  border: 2px solid hsl(var(--dashboard-accent));
  background-color: hsl(var(--a11y-fab-bg));
  color: hsl(var(--a11y-fab-fg));
  cursor: pointer;
  transition: all 0.15s cubic-bezier(0.4, 0, 0.2, 1);
  box-shadow: 0 10px 15px -3px hsl(var(--a11y-shadow) / 0.1), 0 4px 6px -4px hsl(var(--a11y-shadow) / 0.1);
}

.accessibility-toggle:hover {
  background-color: hsl(var(--a11y-fab-bg) / 0.8);
  transform: scale(1.1);
}

.accessibility-toggle svg {
  width: 2rem;
  height: 2rem;
}

.accessibility-icon {
  display: none;
}

.accessibility-modal {
  position: fixed;
  inset: 0;
  display: none;
  align-items: center;
  justify-content: center;
  z-index: 50;
  padding: 1rem;
}

.accessibility-modal.accessibility-modal-open {
  display: flex;
}

.accessibility-modal-backdrop {
  position: absolute;
  inset: 0;
  background-color: hsl(var(--a11y-overlay) / 0.2);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  animation: fade-in 0.2s ease-out;
  z-index: -1;
}

.accessibility-modal-content {
  background-color: hsl(var(--dashboard-card));
  border: 1px solid hsl(var(--dashboard-border));
  border-radius: 0.75rem;
  box-shadow: 0 25px 50px -12px hsl(var(--a11y-shadow) / 0.25);
  width: 100%;
  max-width: 42rem;
  max-height: 90vh;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  animation: scale-in 0.2s ease-out;
}

.accessibility-header {
  position: sticky;
  top: 0;
  background-color: hsl(var(--dashboard-card));
  border-bottom: 1px solid hsl(var(--dashboard-border) / 0.3);
  padding: 1.5rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  z-index: 10;
}

.accessibility-header-left {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.accessibility-icon-container {
  background-color: hsl(var(--dashboard-accent) / 0.1);
  padding: 0.5rem;
  border-radius: 0.5rem;
}

.accessibility-icon-container svg {
  width: 1.5rem;
  height: 1.5rem;
  color: hsl(var(--dashboard-accent));
}

.accessibility-title {
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 1;
  color: hsl(var(--dashboard-text));
  margin: 0;
}

.accessibility-subtitle {
  font-size: 0.875rem;
  color: hsl(var(--dashboard-text-muted));
  margin: 0;
  margin-top: 0.25rem;
}

.accessibility-close {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  border-radius: 0.375rem;
  background-color: transparent;
  border: none;
  color: hsl(var(--dashboard-text));
  cursor: pointer;
  transition: background-color 0.2s;
}

.accessibility-close:hover {
  background-color: hsl(var(--dashboard-card-hover));
}

.accessibility-close svg {
  width: 1.25rem;
  height: 1.25rem;
}

.accessibility-content {
  padding: 1.5rem;
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

.accessibility-section {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.accessibility-section-header {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.accessibility-section-header svg {
  width: 1.25rem;
  height: 1.25rem;
  color: hsl(var(--dashboard-accent));
}

.accessibility-section-title {
  font-size: 1.125rem;
  font-weight: 600;
  color: hsl(var(--dashboard-text));
  margin: 0;
  cursor: default;
}

.accessibility-separator {
  height: 1px;
  background-color: hsl(var(--dashboard-border) / 0.3);
  margin: 0;
}

.accessibility-text-size-controls {
  display: flex;
  align-items: center;
  gap: 1rem;
}

.accessibility-button-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 0.375rem;
  border: 1px solid hsl(var(--dashboard-border));
  background-color: hsl(var(--a11y-fab-bg));
  color: hsl(var(--a11y-fab-fg));
  cursor: pointer;
  transition: all 0.2s;
}

.accessibility-button-icon:hover:not(:disabled) {
  background-color: hsl(var(--a11y-fab-bg) / 0.8);
}

.accessibility-button-icon:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.accessibility-button-icon svg {
  width: 1rem;
  height: 1rem;
}

.accessibility-font-size-value {
  font-weight: 500;
  color: hsl(var(--dashboard-text));
  min-width: 5rem;
  text-align: center;
}

.accessibility-control-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.accessibility-control-label-group {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.accessibility-control-label {
  font-size: 1rem;
  color: hsl(var(--dashboard-text));
  cursor: pointer;
}

.accessibility-control-description {
  font-size: 0.875rem;
  color: hsl(var(--dashboard-text-muted));
  margin: 0;
}

.accessibility-footer {
  position: sticky;
  bottom: 0;
  background-color: hsl(var(--dashboard-card));
  border-top: 1px solid hsl(var(--dashboard-border) / 0.3);
  padding: 1.5rem;
  display: flex;
  justify-content: space-between;
  gap: 0.75rem;
}

.accessibility-button-primary,
.accessibility-button-secondary {
  padding: 0.5rem 1rem;
  border-radius: 0.375rem;
  font-size: 0.875rem;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.2s;
  border: 1px solid hsl(var(--dashboard-accent));
}

.accessibility-button-primary {
  background-color: hsl(var(--a11y-fab-bg));
  color: hsl(var(--a11y-fab-fg));
}

.accessibility-button-primary:hover {
  background-color: hsl(var(--a11y-fab-bg) / 0.8);
}

.accessibility-button-secondary {
  background-color: hsl(var(--a11y-fab-bg));
  color: hsl(var(--a11y-fab-fg));
}

.accessibility-button-secondary:hover {
  background-color: hsl(var(--a11y-fab-bg) / 0.8);
}



/* ============================================
   Module: auth.css
   ============================================ */

/* Switch input styling */
.switch-input {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
  pointer-events: none;
}

/* Switch with checkbox - using :has() for modern browsers */
.switch:has(.switch-input:checked) {
  background-color: hsl(var(--primary));
}

.switch:has(.switch-input:checked) .switch-thumb {
  transform: translateX(1.25rem);
}

.switch:has(.switch-input:not(:checked)) {
  background-color: hsl(var(--input));
}

.switch:has(.switch-input:not(:checked)) .switch-thumb {
  transform: translateX(0);
}

/* Fallback for browsers without :has() support - using data-state */
.switch[data-state="checked"] {
  background-color: hsl(var(--primary));
}

.switch[data-state="checked"] .switch-thumb {
  transform: translateX(1.25rem);
}

.switch[data-state="unchecked"] {
  background-color: hsl(var(--input));
}

.switch[data-state="unchecked"] .switch-thumb {
  transform: translateX(0);
}

/* ============================================
   Feedback Widget
   ============================================ */

.feedback-widget {
  position: relative;
}

.feedback-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 3rem;
  height: 3rem;
  padding: 0;
  border-radius: 9999px;
  border: 2px solid hsl(var(--dashboard-accent));
  background-color: hsl(var(--a11y-fab-bg));
  color: hsl(var(--a11y-fab-fg));
  cursor: pointer;
  transition: all 0.15s cubic-bezier(0.4, 0, 0.2, 1);
  box-shadow: 0 10px 15px -3px hsl(var(--a11y-shadow) / 0.1), 0 4px 6px -4px hsl(var(--a11y-shadow) / 0.1);
}

.feedback-toggle:hover {
  background-color: hsl(var(--a11y-fab-bg) / 0.8);
  transform: scale(1.1);
}

.feedback-toggle svg {
  width: 2rem;
  height: 2rem;
}

/* ============================================
   Animations
   ============================================ */

@keyframes fade-in {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

@keyframes scale-in {
  from {
    opacity: 0;
    transform: scale(0.95);
  }
  to {
    opacity: 1;
    transform: scale(1);
  }
}

/* ============================================
   Light Mode Support
   ============================================ */

/* ============================================
   Accessibility Logic (applied by JS)
   ============================================ */

html.high-contrast {
  --muted-foreground: var(--foreground);
  --dashboard-text-muted: var(--dashboard-text);
  --border: var(--foreground);
  --input: var(--foreground);
  filter: contrast(1.15);
}

html.a11y-font-80 { font-size: 80%; }
html.a11y-font-90 { font-size: 90%; }
html.a11y-font-110 { font-size: 110%; }
html.a11y-font-120 { font-size: 120%; }
html.a11y-font-130 { font-size: 130%; }
html.a11y-font-140 { font-size: 140%; }
html.a11y-font-150 { font-size: 150%; }

html.readable-font body {
  font-family: Arial, Verdana, Tahoma, system-ui, -apple-system, "Segoe UI", sans-serif;
}

html.highlight-links a {
  text-decoration-line: underline;
  text-decoration-thickness: 2px;
  text-underline-offset: 2px;
}

html.text-spacing body,
html.text-spacing p,
html.text-spacing li,
html.text-spacing a,
html.text-spacing label,
html.text-spacing button,
html.text-spacing input,
html.text-spacing textarea,
html.text-spacing select {
  letter-spacing: 0.06em;
  word-spacing: 0.12em;
  line-height: 1.6;
}

html.large-cursor,
html.large-cursor * {
  cursor: none;
}

#a11y-large-cursor {
  position: fixed;
  top: -9999px;
  left: -9999px;
  width: 32px;
  height: 32px;
  background-color: hsl(var(--a11y-fab-fg));
  clip-path: polygon(
    0% 0%,
    0% 75%,
    18% 60%,
    32% 96%,
    44% 92%,
    30% 56%,
    60% 56%
  );
  filter:
    drop-shadow(0 10px 15px hsl(var(--a11y-shadow) / 0.18))
    drop-shadow(0 4px 6px hsl(var(--a11y-shadow) / 0.18));
  pointer-events: none;
  z-index: 2147483646;
  will-change: left, top;
}

#a11y-large-cursor::after {
  content: "";
  position: absolute;
  inset: 0;
  background-color: transparent;
  clip-path: polygon(
    6% 6%,
    6% 70%,
    20% 58%,
    33% 90%,
    40% 87%,
    28% 56%,
    56% 56%
  );
  background-color: hsl(var(--a11y-shadow) / 0.6);
}

html.keyboard-nav :focus {
  outline: 2px solid hsl(var(--ring));
  outline-offset: 2px;
}

/* ============================================
   AUTH PAGE STYLES (SystemV Design)
   ============================================ */

.auth-page {
  min-height: 100vh;
  background: hsl(var(--background));
  position: relative;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Animated Background */
.auth-background {
  position: absolute;
  inset: 0;
  overflow: hidden;
  z-index: 0;
}

.auth-glow {
  position: absolute;
  border-radius: 50%;
  filter: blur(120px);
  animation: gentleGlow 8s ease-in-out infinite;
}

.auth-glow-1 {
  top: 33%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 600px;
  height: 600px;
  background: hsl(var(--accent) / 0.3);
}

.auth-glow-2 {
  bottom: 25%;
  right: 33%;
  width: 400px;
  height: 400px;
  background: hsl(var(--accent) / 0.25);
  animation-delay: 4s;
}

@keyframes gentleGlow {
  0%, 100% {
    opacity: 0.6;
    transform: scale(0.95);
  }
  50% {
    opacity: 1;
    transform: scale(1.05);
  }
}

.auth-hexagon {
  position: absolute;
  opacity: 0;
  transform: scale(0);
  animation: popIn ease-in-out infinite;
}

.auth-hexagon svg {
  width: 100%;
  height: 100%;
  display: block;
}

.auth-hexagon polygon {
  fill: none;
  stroke: hsl(var(--accent));
  stroke-width: 1.5;
  opacity: 0.8;
}

@keyframes popIn {
  0%, 100% {
    opacity: 0;
    transform: scale(0);
  }
  15% {
    opacity: 0.7;
    transform: scale(1);
  }
  85% {
    opacity: 0.7;
    transform: scale(1);
  }
}

/* Main Content */
.auth-content {
  position: relative;
  z-index: 10;
  width: 100%;
  max-width: 1280px;
  margin: 0 auto;
  padding: 3rem 1.5rem;
}

.auth-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 3rem;
  align-items: center;
}

@media (min-width: 1024px) {
  .auth-grid {
    grid-template-columns: 1fr 1fr;
  }
}

/* Left Side - Branding */
.auth-branding {
  display: none;
  flex-direction: column;
  gap: 2rem;
}

@media (min-width: 1024px) {
  .auth-branding {
    display: flex;
  }
}

.auth-logo-section {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin-bottom: 3rem;
}

.auth-logo-glow {
  position: relative;
}

.auth-logo-glow::before {
  content: '';
  position: absolute;
  inset: 0;
  background: hsl(var(--accent) / 0.3);
  filter: blur(20px);
  border-radius: 50%;
  z-index: 0;
}

.auth-logo-img {
  width: 4rem;
  height: 4rem;
  position: relative;
  z-index: 10;
  border-radius: 0.75rem;
  object-fit: cover;
}

.auth-logo-text {
  display: flex;
  flex-direction: column;
}

.auth-logo-title {
  font-size: 1.875rem;
  font-weight: 700;
  color: hsl(var(--foreground));
  letter-spacing: -0.025em;
  line-height: 1;
}

.auth-logo-accent {
  color: hsl(var(--accent));
}

.auth-logo-subtitle {
  color: hsl(var(--muted-foreground));
  font-size: 0.875rem;
}

.auth-tagline {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.auth-tagline-title {
  font-size: 2.25rem;
  font-weight: 700;
  color: hsl(var(--foreground));
  line-height: 1.2;
}

.auth-tagline-accent {
  color: hsl(var(--accent));
  display: block;
}

.auth-tagline-text {
  color: hsl(var(--muted-foreground));
  font-size: 1.125rem;
  line-height: 1.6;
}

.auth-features {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  padding-top: 1.5rem;
}

.auth-feature-item {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 1rem;
  border-radius: 0.75rem;
  background: hsl(var(--card) / 0.5);
  border: 1px solid hsl(var(--border) / 0.2);
  backdrop-filter: blur(4px);
  transition: all 0.3s;
}

.auth-feature-item:hover {
  border-color: hsl(var(--accent) / 0.4);
}

.auth-feature-icon {
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 0.5rem;
  background: hsl(var(--accent) / 0.1);
  display: flex;
  align-items: center;
  justify-content: center;
  color: hsl(var(--accent));
  transition: background-color 0.3s;
}

.auth-feature-item:hover .auth-feature-icon {
  background: hsl(var(--accent) / 0.2);
}

.auth-feature-text {
  color: hsl(var(--foreground));
  font-weight: 500;
}

/* Right Side - Auth Form */
.auth-form-wrapper {
  width: 100%;
  max-width: 28rem;
  margin: 0 auto;
}

@media (min-width: 1024px) {
  .auth-form-wrapper {
    margin: 0;
  }
}

.auth-card {
  background: hsl(var(--card) / 0.8);
  backdrop-filter: blur(20px);
  border: 1px solid hsl(var(--border) / 0.3);
  border-radius: 0.75rem;
  box-shadow: 0 20px 25px -5px hsl(var(--accent) / 0.05);
  overflow: hidden;
}

.auth-card-accent {
  height: 4px;
  background: linear-gradient(to right, hsl(var(--accent)), hsl(var(--accent) / 0.8), hsl(var(--accent)));
}

.auth-card-content {
  padding: 2rem;
}

/* Mobile Logo */
.auth-mobile-logo {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
  margin-bottom: 2rem;
}

@media (min-width: 1024px) {
  .auth-mobile-logo {
    display: none;
  }
}

.auth-mobile-logo-img {
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 0.5rem;
  object-fit: cover;
}

.auth-mobile-logo-text {
  font-size: 1.25rem;
  font-weight: 700;
  color: hsl(var(--foreground));
}

/* Toggle */
.auth-toggle {
  display: flex;
  gap: 0.5rem;
  padding: 0.25rem;
  background: hsl(var(--background));
  border-radius: 0.75rem;
  margin-bottom: 2rem;
  position: relative;
}

.auth-toggle-indicator {
  position: absolute;
  top: 0.25rem;
  bottom: 0.25rem;
  width: calc(50% - 0.25rem);
  background: hsl(var(--accent));
  border-radius: 0.5rem;
  box-shadow: 0 4px 6px -1px hsl(var(--accent) / 0.25);
  transition: left 0.3s ease-out;
  left: 4px;
}

.auth-toggle-btn {
  flex: 1;
  padding: 0.75rem 1rem;
  border-radius: 0.5rem;
  font-weight: 500;
  font-size: 0.875rem;
  transition: all 0.3s;
  position: relative;
  z-index: 10;
  background: transparent;
  border: none;
  cursor: pointer;
  color: hsl(var(--muted-foreground));
}

.auth-toggle-btn:hover {
  color: hsl(var(--foreground));
}

.auth-toggle-btn-active {
  color: hsl(var(--background));
}

/* Form */
.auth-form-container {
  transition: all 0.3s;
}

.auth-form {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

.auth-form-group {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.auth-form-group-forgot {
  align-items: flex-end;
  margin-top: 0.25rem;
}

.auth-label {
  color: hsl(var(--muted-foreground));
  font-size: 0.875rem;
}

.auth-input-wrapper {
  position: relative;
  display: flex;
  align-items: stretch;
}

.auth-input-icon {
  position: absolute;
  left: 1rem;
  top: 50%;
  transform: translateY(-50%);
  width: 1.25rem;
  height: 1.25rem;
  color: hsl(var(--muted-foreground));
  transition: color 0.3s;
  pointer-events: none;
  z-index: 1;
}

.auth-input-wrapper:focus-within .auth-input-icon {
  color: hsl(var(--accent));
}

.auth-input {
  width: 100%;
  padding: 0.75rem 1rem 0.75rem 3rem;
  height: 3rem;
  background: hsl(var(--background));
  border: 1px solid hsl(var(--border) / 0.3);
  border-radius: 0.75rem;
  color: hsl(var(--foreground));
  font-size: 1rem;
  transition: all 0.3s;
  box-sizing: border-box;
}

.auth-input::placeholder {
  color: hsl(var(--muted-foreground) / 0.5);
}

.auth-input:focus {
  outline: none;
  border-color: hsl(var(--accent));
  box-shadow: 0 0 0 1px hsl(var(--accent) / 0.2);
}

.auth-password-toggle {
  position: absolute;
  right: 1rem;
  top: 50%;
  transform: translateY(-50%);
  background: none;
  border: none;
  color: hsl(var(--muted-foreground));
  cursor: pointer;
  padding: 0.25rem;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: color 0.3s;
  z-index: 1;
}

.auth-password-toggle:hover {
  color: hsl(var(--accent));
}

.auth-password-icon {
  width: 1.25rem;
  height: 1.25rem;
}

.auth-forgot-link {
  font-size: 0.875rem;
  color: hsl(var(--accent));
  text-decoration: none;
  transition: color 0.3s;
}

.auth-forgot-link:hover {
  color: hsl(var(--accent) / 0.8);
}

.auth-submit-btn {
  width: 100%;
  height: 3rem;
  background: hsl(var(--accent));
  color: hsl(var(--accent-foreground));
  font-weight: 600;
  border-radius: 0.75rem;
  border: none;
  box-shadow: 0 4px 6px -1px hsl(var(--accent) / 0.25);
  cursor: pointer;
  transition: all 0.3s;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  font-size: 1rem;
}

.auth-submit-btn:hover {
  background: hsl(var(--accent) / 0.9);
  box-shadow: 0 8px 12px -2px hsl(var(--accent) / 0.4);
}

.auth-submit-btn svg {
  transition: transform 0.3s;
}

.auth-submit-btn:hover svg {
  transform: translateX(4px);
}

/* Coming Soon */
.auth-form-register {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
}

.auth-coming-soon {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 3rem 1rem;
  gap: 1rem;
}

.auth-coming-soon-icon {
  color: hsl(var(--accent));
  margin-bottom: 0.5rem;
}

.auth-coming-soon-title {
  font-size: 1.5rem;
  font-weight: 700;
  color: hsl(var(--foreground));
  margin: 0;
}

.auth-coming-soon-text {
  color: hsl(var(--muted-foreground));
  font-size: 0.875rem;
  line-height: 1.6;
  max-width: 20rem;
  margin: 0;
}

/* Terms */
.auth-terms {
  text-align: center;
  font-size: 0.75rem;
  color: hsl(var(--muted-foreground));
  margin-top: 1.5rem;
  margin-bottom: 0;
}

.auth-terms-link {
  color: hsl(var(--accent));
  text-decoration: none;
  transition: color 0.3s;
}

.auth-terms-link:hover {
  text-decoration: underline;
}

/* ============================================
   Campaign Detail Drawer
   ============================================ */

.campaign-drawer {
  position: fixed;
  inset: 0;
  z-index: 50;
  pointer-events: none;
}

.campaign-drawer[aria-hidden="false"] {
  pointer-events: auto;
}

.campaign-drawer-overlay {
  position: fixed;
  inset: 0;
  background: hsl(var(--a11y-overlay) / 0.8);
  opacity: 0;
  transition: opacity 0.3s ease-in-out;
  pointer-events: none;
  z-index: 50;
}

.campaign-drawer[aria-hidden="false"] .campaign-drawer-overlay {
  opacity: 1;
  pointer-events: auto;
  cursor: pointer;
}

.campaign-drawer-content {
  position: fixed;
  right: 0;
  top: 0;
  bottom: 0;
  width: 100%;
  max-width: 50vw;
  background: hsl(var(--dashboard-bg));
  border-left: 1px solid hsl(var(--dashboard-border));
  box-shadow: -4px 0 24px hsl(var(--a11y-shadow) / 0.5);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  transform: translateX(100%);
  transition: transform 0.5s ease-in-out;
  z-index: 51;
  pointer-events: auto;
}

.campaign-drawer[aria-hidden="false"] .campaign-drawer-content {
  transform: translateX(0);
}

.campaign-drawer-header {
  position: sticky;
  top: 0;
  z-index: 10;
  background: hsl(var(--dashboard-bg));
  border-bottom: 1px solid hsl(var(--dashboard-border) / 0.3);
  padding: 1rem 1.5rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}

.campaign-drawer-header-content {
  flex: 1;
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.campaign-drawer-close {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  border-radius: 0.375rem;
  background: transparent;
  border: none;
  color: hsl(var(--dashboard-text-muted));
  cursor: pointer;
  transition: all 0.2s;
  flex-shrink: 0;
}

.campaign-drawer-close:hover {
  background: hsl(var(--dashboard-accent) / 0.1);
  color: hsl(var(--dashboard-accent));
}

.campaign-drawer-body {
  flex: 1;
  overflow-y: auto;
  padding: 1rem 1.5rem;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}



/* ============================================
   Module: drawer.css
   ============================================ */

/* Drawer Navigation Breadcrumb */
.campaign-drawer-breadcrumb {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.875rem;
  margin-bottom: 1rem;
  padding: 0 0.25rem;
}

.campaign-drawer-breadcrumb-item {
  display: flex;
  align-items: center;
  gap: 0.25rem;
  color: hsl(var(--dashboard-text-muted));
  transition: color 0.2s;
  background: none;
  border: none;
  cursor: pointer;
  padding: 0;
  font-size: 0.875rem;
}

.campaign-drawer-breadcrumb-item:hover {
  color: hsl(var(--dashboard-text));
}

.campaign-drawer-breadcrumb-item.active {
  color: hsl(var(--dashboard-accent));
  font-weight: 500;
}

.campaign-drawer-breadcrumb-separator {
  color: hsl(var(--dashboard-text-muted));
  width: 0.75rem;
  height: 0.75rem;
}

/* Drawer Back Button */
.campaign-drawer-back-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  border-radius: 0.375rem;
  background: transparent;
  border: none;
  color: hsl(var(--dashboard-text-muted));
  cursor: pointer;
  transition: all 0.2s;
  flex-shrink: 0;
}

.campaign-drawer-back-btn:hover {
  background: hsl(var(--dashboard-accent) / 0.1);
  color: hsl(var(--dashboard-accent));
}

/* Drawer View Header */
.campaign-drawer-view-header {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.campaign-drawer-view-header-icon {
  width: 1.25rem;
  height: 1.25rem;
  color: hsl(var(--dashboard-accent));
}

.campaign-drawer-view-header-icon-wrapper {
  display: flex;
  align-items: center;
  justify-content: center;
}

.campaign-drawer-view-header-content {
  flex: 1;
}

.campaign-drawer-view-header-title {
  font-size: 1.125rem;
  font-weight: 600;
  color: hsl(var(--dashboard-text));
  margin: 0;
  line-height: 1.4;
}

.campaign-drawer-view-header-subtitle {
  font-size: 0.75rem;
  color: hsl(var(--dashboard-text-muted));
  margin: 0;
  margin-top: 0.125rem;
}

/* Drawer Hierarchy List */
.campaign-drawer-hierarchy-list {
  background: hsl(var(--dashboard-card));
  border: 1px solid hsl(var(--dashboard-border) / 0.3);
  border-radius: 0.75rem;
  padding: 1rem;
}

.campaign-drawer-hierarchy-list-title {
  font-size: 0.875rem;
  font-weight: 600;
  color: hsl(var(--dashboard-text));
  margin: 0 0 0.75rem 0;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.campaign-drawer-hierarchy-list-items {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.campaign-drawer-hierarchy-item {
  width: 100%;
  padding: 0.75rem;
  background: hsl(var(--dashboard-bg));
  border-radius: 0.5rem;
  border: 1px solid hsl(var(--dashboard-border) / 0.2);
  cursor: pointer;
  transition: all 0.2s;
  text-align: left;
}

.campaign-drawer-hierarchy-item:hover {
  border-color: hsl(var(--dashboard-accent) / 0.5);
  background: hsl(var(--dashboard-card));
}

.campaign-drawer-hierarchy-item-content {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.campaign-drawer-hierarchy-item-left {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.campaign-drawer-hierarchy-item-icon {
  width: 1rem;
  height: 1rem;
  color: hsl(var(--dashboard-accent));
}

.campaign-drawer-hierarchy-item-info {
  display: flex;
  flex-direction: column;
  gap: 0.125rem;
}

.campaign-drawer-hierarchy-item-name {
  font-size: 0.875rem;
  font-weight: 500;
  color: hsl(var(--dashboard-text));
  transition: color 0.2s;
}

.campaign-drawer-hierarchy-item:hover .campaign-drawer-hierarchy-item-name {
  color: hsl(var(--dashboard-accent));
}

.campaign-drawer-hierarchy-item-meta {
  font-size: 0.75rem;
  color: hsl(var(--dashboard-text-muted));
}

.campaign-drawer-hierarchy-item-right {
  display: flex;
  align-items: center;
  gap: 1rem;
  font-size: 0.75rem;
}

.campaign-drawer-hierarchy-item-metric {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 0.125rem;
}

.campaign-drawer-hierarchy-item-metric-label {
  color: hsl(var(--dashboard-text-muted));
}

.campaign-drawer-hierarchy-item-metric-value {
  color: hsl(var(--dashboard-text));
  font-weight: 500;
}

.campaign-drawer-hierarchy-item-chevron {
  width: 1rem;
  height: 1rem;
  color: hsl(var(--dashboard-text-muted));
  transition: color 0.2s;
}

.campaign-drawer-hierarchy-item:hover .campaign-drawer-hierarchy-item-chevron {
  color: hsl(var(--dashboard-accent));
}

/* Drawer Level Info */
.campaign-drawer-level-info {
  background: hsl(var(--dashboard-card));
  border: 1px solid hsl(var(--dashboard-border) / 0.3);
  border-radius: 0.75rem;
  padding: 1rem;
}

.campaign-drawer-level-info-title {
  font-size: 0.875rem;
  font-weight: 600;
  color: hsl(var(--dashboard-text));
  margin: 0 0 0.75rem 0;
}

.campaign-drawer-level-info-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.75rem;
  font-size: 0.875rem;
}

.campaign-drawer-level-info-item-label {
  font-size: 0.75rem;
  color: hsl(var(--dashboard-text-muted));
}

.campaign-drawer-level-info-item-value {
  color: hsl(var(--dashboard-text));
}

/* Drawer KPI Grid */
.campaign-drawer-kpi-section {
  position: relative;
}

.campaign-drawer-kpi-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 0.75rem;
}

.campaign-drawer-kpi-title {
  font-size: 0.875rem;
  font-weight: 600;
  color: hsl(var(--dashboard-text));
  margin: 0;
}

.campaign-drawer-kpi-count {
  font-size: 0.75rem;
  color: hsl(var(--dashboard-text-muted));
}

.campaign-drawer-kpi-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.5rem;
  align-items: start;
}

.campaign-drawer-kpi-card {
  background: hsl(var(--dashboard-card));
  border: 1px solid hsl(var(--dashboard-border) / 0.3);
  border-radius: 0.5rem;
  padding: 0.625rem;
  transition: all 0.2s;
}

.campaign-drawer-kpi-card:hover {
  border-color: hsl(var(--dashboard-accent) / 0.6);
}

.campaign-drawer-kpi-card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 0.375rem;
}

.campaign-drawer-kpi-card-icon {
  width: 0.875rem;
  height: 0.875rem;
  color: hsl(var(--dashboard-accent));
}

.campaign-drawer-kpi-card-change {
  font-size: 0.625rem;
  font-weight: 500;
}

.campaign-drawer-kpi-card-value {
  font-size: 0.875rem;
  font-weight: 700;
  color: hsl(var(--dashboard-text));
  margin: 0;
  line-height: 1.2;
}

.campaign-drawer-kpi-card-label {
  font-size: 0.625rem;
  color: hsl(var(--dashboard-text-muted));
  margin: 0;
  margin-top: 0.125rem;
}

.campaign-drawer-kpi-add-card {
  background: hsl(var(--dashboard-card));
  border: 1px solid hsl(var(--dashboard-border) / 0.3);
  border-radius: 0.5rem;
  padding: 0.625rem;
  cursor: pointer;
  transition: all 0.3s;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 5rem;
}

.campaign-drawer-kpi-add-card:hover {
  border-color: hsl(var(--dashboard-accent));
  box-shadow: 0 0 0.5rem hsl(var(--dashboard-accent) / 0.2);
}

.campaign-drawer-kpi-add-icon {
  width: 1rem;
  height: 1rem;
  color: hsl(var(--dashboard-accent));
}

/* Drawer Charts */
.campaign-drawer-charts-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.75rem;
}

.campaign-drawer-chart-card {
  background: hsl(var(--dashboard-card));
  border: 1px solid hsl(var(--dashboard-border) / 0.3);
  border-radius: 0.75rem;
  padding: 0.75rem;
}

.campaign-drawer-chart-title {
  font-size: 0.75rem;
  font-weight: 600;
  color: hsl(var(--dashboard-text));
  margin: 0 0 0.5rem 0;
}

.campaign-drawer-chart-container {
  height: 9.375rem;
  position: relative;
}

/* Drawer Conversion Funnel */
.campaign-drawer-funnel {
  background: hsl(var(--dashboard-card));
  border: 1px solid hsl(var(--dashboard-border) / 0.3);
  border-radius: 0.75rem;
  padding: 0.75rem;
}

.campaign-drawer-funnel-title {
  font-size: 0.75rem;
  font-weight: 600;
  color: hsl(var(--dashboard-text));
  margin: 0 0 0.75rem 0;
}

.campaign-drawer-funnel-items {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.campaign-drawer-funnel-item {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.campaign-drawer-funnel-item-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.campaign-drawer-funnel-item-name {
  font-size: 0.75rem;
  color: hsl(var(--dashboard-text));
}

.campaign-drawer-funnel-item-value {
  font-size: 0.75rem;
  font-weight: 500;
  color: hsl(var(--dashboard-text));
}

.campaign-drawer-funnel-item-bar {
  height: 0.375rem;
  background: hsl(var(--dashboard-bg));
  border-radius: 9999px;
  overflow: hidden;
}

.campaign-drawer-funnel-item-fill {
  height: 100%;
  border-radius: 9999px;
  transition: width 0.3s;
}

.campaign-drawer-funnel-item-conv {
  font-size: 0.625rem;
  color: hsl(var(--dashboard-text-muted));
  margin-top: 0.125rem;
  text-align: right;
}

/* Drawer Placement Performance */
.campaign-drawer-placement {
  background: hsl(var(--dashboard-card));
  border: 1px solid hsl(var(--dashboard-border) / 0.3);
  border-radius: 0.75rem;
  padding: 0.75rem;
}

.campaign-drawer-placement-title {
  font-size: 0.75rem;
  font-weight: 600;
  color: hsl(var(--dashboard-text));
  margin: 0 0 0.75rem 0;
}

.campaign-drawer-placement-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.5rem;
}

.campaign-drawer-placement-item {
  position: relative;
  padding: 0.625rem;
  border-radius: 0.5rem;
  border: 1px solid hsl(var(--dashboard-border) / 0.3);
  transition: all 0.2s;
  overflow: hidden;
}

.campaign-drawer-placement-item:hover {
  border-color: hsl(var(--dashboard-accent) / 0.5);
}

.campaign-drawer-placement-item-bg {
  position: absolute;
  inset: 0;
  opacity: 0.2;
}

.campaign-drawer-placement-item-content {
  position: relative;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.campaign-drawer-placement-item-icon {
  padding: 0.375rem;
  border-radius: 0.5rem;
  background: hsl(var(--dashboard-accent) / 0.2);
  color: hsl(var(--dashboard-accent));
  width: 1.5rem;
  height: 1.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
}

.campaign-drawer-placement-item-info {
  flex: 1;
  min-width: 0;
}

.campaign-drawer-placement-item-name {
  font-size: 0.75rem;
  font-weight: 500;
  color: hsl(var(--dashboard-text));
}

.campaign-drawer-placement-item-meta {
  font-size: 0.625rem;
  color: hsl(var(--dashboard-text-muted));
}

.campaign-drawer-placement-item-metrics {
  text-align: right;
}

.campaign-drawer-placement-item-ctr {
  font-size: 0.875rem;
  font-weight: 700;
  color: hsl(var(--dashboard-accent));
}

.campaign-drawer-placement-item-ctr-label {
  font-size: 0.625rem;
  color: hsl(var(--dashboard-text-muted));
}

/* Drawer Demographics */
.campaign-drawer-demographics-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.75rem;
}

.campaign-drawer-demographics-card {
  background: hsl(var(--dashboard-card));
  border: 1px solid hsl(var(--dashboard-border) / 0.3);
  border-radius: 0.75rem;
  padding: 0.75rem;
}

.campaign-drawer-demographics-title {
  font-size: 0.75rem;
  font-weight: 600;
  color: hsl(var(--dashboard-text));
  margin: 0 0 0.75rem 0;
}

.campaign-drawer-demographics-items {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.campaign-drawer-demographics-item {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.campaign-drawer-demographics-item-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.campaign-drawer-demographics-item-label {
  font-size: 0.625rem;
  color: hsl(var(--dashboard-text-muted));
}

.campaign-drawer-demographics-item-value {
  font-size: 0.75rem;
  font-weight: 700;
  color: hsl(var(--dashboard-accent));
}

.campaign-drawer-demographics-item-bar {
  height: 0.375rem;
  background: hsl(var(--dashboard-bg) / 0.5);
  border-radius: 9999px;
  overflow: hidden;
}

.campaign-drawer-demographics-item-fill {
  height: 100%;
  border-radius: 9999px;
  background: linear-gradient(90deg, hsl(var(--dashboard-accent)) 0%, hsl(var(--dashboard-accent) / 0.6) 100%);
  transition: width 0.3s;
}

/* Drawer Locations */
.campaign-drawer-locations {
  background: hsl(var(--dashboard-card));
  border: 1px solid hsl(var(--dashboard-border) / 0.3);
  border-radius: 0.75rem;
  padding: 0.75rem;
}

.campaign-drawer-locations-title {
  font-size: 0.75rem;
  font-weight: 600;
  color: hsl(var(--dashboard-text));
  margin: 0 0 0.75rem 0;
  display: flex;
  align-items: center;
  gap: 0.375rem;
}

.campaign-drawer-locations-icon {
  width: 0.875rem;
  height: 0.875rem;
  color: hsl(var(--dashboard-accent));
}

.campaign-drawer-locations-items {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.campaign-drawer-locations-item {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.campaign-drawer-locations-item-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.campaign-drawer-locations-item-name {
  font-size: 0.75rem;
  font-weight: 500;
  color: hsl(var(--dashboard-text));
}

.campaign-drawer-locations-item-country {
  font-size: 0.625rem;
  color: hsl(var(--dashboard-text-muted));
  margin-left: 0.25rem;
}

.campaign-drawer-locations-item-value {
  font-size: 0.75rem;
  font-weight: 700;
  color: hsl(var(--dashboard-accent));
}

.campaign-drawer-locations-item-bar {
  height: 0.375rem;
  background: hsl(var(--dashboard-bg) / 0.5);
  border-radius: 9999px;
  overflow: hidden;
}

.campaign-drawer-locations-item-fill {
  height: 100%;
  border-radius: 9999px;
  background: linear-gradient(90deg, hsl(var(--dashboard-accent)) 0%, hsl(var(--dashboard-accent) / 0.6) 100%);
  transition: width 0.3s;
}

/* Drawer KPI Selector Modal */
.drawer-kpi-selector-modal {
  position: fixed;
  inset: 0;
  z-index: 120;
  display: none;
  align-items: center;
  justify-content: center;
  pointer-events: none;
}

.drawer-kpi-selector-modal[aria-hidden="false"] {
  display: flex;
  pointer-events: auto;
}

.drawer-kpi-selector-modal[aria-hidden="true"] {
  display: none;
  pointer-events: none;
}

.drawer-kpi-selector-overlay {
  position: absolute;
  inset: 0;
  background: hsl(var(--dashboard-bg) / 0.7);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  pointer-events: auto;
}

.drawer-kpi-selector-content {
  position: relative;
  background: hsl(var(--dashboard-card));
  border: 2px solid hsl(var(--dashboard-accent) / 0.5);
  border-radius: 0.75rem;
  box-shadow: 0 0 2rem hsl(var(--dashboard-accent) / 0.2);
  width: 100%;
  max-width: 37.5rem;
  max-height: min(43.75rem, 85vh);
  height: min(43.75rem, 85vh);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  z-index: 130;
  pointer-events: auto;
}

.drawer-kpi-selector-header {
  position: relative;
  background: linear-gradient(90deg, hsl(var(--dashboard-accent) / 0.2) 0%, hsl(var(--dashboard-accent) / 0.1) 50%, transparent 100%);
  padding: 1rem;
  border-bottom: 1px solid hsl(var(--dashboard-accent) / 0.3);
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-shrink: 0;
}

.drawer-kpi-selector-header::before {
  content: '';
  position: absolute;
  top: 0;
  right: 0;
  width: 6rem;
  height: 6rem;
  background: hsl(var(--dashboard-accent) / 0.05);
  border-radius: 50%;
  filter: blur(3rem);
  pointer-events: none;
}

.drawer-kpi-selector-header-left {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  position: relative;
  z-index: 1;
}

.drawer-kpi-selector-header-icon {
  padding: 0.5rem;
  background: hsl(var(--dashboard-accent));
  border-radius: 0.5rem;
  color: hsl(var(--dashboard-bg));
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
}

.drawer-kpi-selector-title {
  font-size: 1.125rem;
  font-weight: 700;
  color: hsl(var(--dashboard-text));
  margin: 0;
  line-height: 1.4;
}

.drawer-kpi-selector-subtitle {
  font-size: 0.75rem;
  color: hsl(var(--dashboard-text-muted));
  margin: 0;
  margin-top: 0.125rem;
}

.drawer-kpi-selector-close {
  padding: 0.375rem;
  border-radius: 0.375rem;
  background: transparent;
  border: none;
  color: hsl(var(--dashboard-text-muted));
  cursor: pointer;
  transition: all 0.2s;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  z-index: 1;
}

.drawer-kpi-selector-close:hover {
  background: hsl(var(--dashboard-bg) / 0.5);
  color: hsl(var(--dashboard-text));
}

.drawer-kpi-selector-body {
  flex: 1;
  display: flex;
  min-height: 0;
  overflow: hidden;
}

.drawer-kpi-selector-sidebar {
  width: 12rem;
  background: hsl(var(--dashboard-bg) / 0.5);
  border-right: 1px solid hsl(var(--dashboard-border) / 0.3);
  padding: 0.5rem;
  overflow-y: auto;
  flex-shrink: 0;
  scrollbar-width: thin;
  scrollbar-color: hsl(var(--dashboard-accent) / 0.5) transparent;
}

.drawer-kpi-selector-sidebar::-webkit-scrollbar {
  width: 6px;
}

.drawer-kpi-selector-sidebar::-webkit-scrollbar-track {
  background: transparent;
}

.drawer-kpi-selector-sidebar::-webkit-scrollbar-thumb {
  background: hsl(var(--dashboard-accent) / 0.5);
  border-radius: 3px;
}

.drawer-kpi-category-btn {
  width: 100%;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.5rem;
  border-radius: 0.5rem;
  text-align: left;
  transition: all 0.2s;
  background: transparent;
  border: 1px solid transparent;
  cursor: pointer;
  margin-bottom: 0.25rem;
}

.drawer-kpi-category-btn:hover {
  background: hsl(var(--dashboard-accent) / 0.1);
  border-color: hsl(var(--dashboard-accent) / 0.3);
}

.drawer-kpi-category-btn.active {
  background: hsl(var(--dashboard-accent));
  color: hsl(var(--dashboard-bg));
  box-shadow: 0 0 0.5rem hsl(var(--dashboard-accent) / 0.3);
}

.drawer-kpi-category-btn.active .drawer-kpi-category-name {
  color: hsl(var(--dashboard-bg));
}

.drawer-kpi-category-icon {
  width: 0.875rem;
  height: 0.875rem;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.drawer-kpi-category-icon svg {
  width: 100%;
  height: 100%;
}

.drawer-kpi-category-name {
  font-size: 0.6875rem;
  font-weight: 500;
  flex: 1;
  line-height: 1.2;
  color: hsl(var(--dashboard-text));
}

.drawer-kpi-category-count {
  font-size: 0.625rem;
  font-weight: 700;
  padding: 0.125rem 0.375rem;
  border-radius: 9999px;
  flex-shrink: 0;
}

.drawer-kpi-category-btn.active .drawer-kpi-category-count {
  background: hsl(var(--dashboard-bg) / 0.3);
  color: hsl(var(--dashboard-bg));
}

.drawer-kpi-category-btn:not(.active) .drawer-kpi-category-count {
  background: hsl(var(--dashboard-accent) / 0.2);
  color: hsl(var(--dashboard-accent));
}

.drawer-kpi-selector-main {
  flex: 1;
  display: flex;
  flex-direction: column;
  min-width: 0;
  min-height: 0;
}

.drawer-kpi-selector-category-header {
  padding: 0.75rem;
  padding-bottom: 0.5rem;
  border-bottom: 1px solid hsl(var(--dashboard-border) / 0.2);
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-shrink: 0;
}

.drawer-kpi-selector-category-icon {
  padding: 0.25rem;
  border-radius: 0.375rem;
  background: hsl(var(--dashboard-accent) / 0.1);
  color: hsl(var(--dashboard-accent));
  display: flex;
  align-items: center;
  justify-content: center;
  width: 1rem;
  height: 1rem;
}

.drawer-kpi-selector-category-icon svg {
  width: 100%;
  height: 100%;
}

.drawer-kpi-selector-category-title {
  font-size: 0.875rem;
  font-weight: 600;
  color: hsl(var(--dashboard-text));
  margin: 0;
}

.drawer-kpi-selector-grid {
  flex: 1;
  overflow-y: auto;
  padding: 0.75rem;
  padding-top: 0.5rem;
  scrollbar-width: thin;
  scrollbar-color: hsl(var(--dashboard-accent) / 0.5) transparent;
}

.drawer-kpi-selector-grid::-webkit-scrollbar {
  width: 6px;
}

.drawer-kpi-selector-grid::-webkit-scrollbar-track {
  background: transparent;
}

.drawer-kpi-selector-grid::-webkit-scrollbar-thumb {
  background: hsl(var(--dashboard-accent) / 0.5);
  border-radius: 3px;
}

.drawer-kpi-selector-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.5rem;
}

.drawer-kpi-option {
  position: relative;
  padding: 0.75rem;
  border-radius: 0.5rem;
  text-align: left;
  transition: all 0.2s;
  border: 1px solid hsl(var(--dashboard-border) / 0.3);
  background: hsl(var(--dashboard-bg) / 0.3);
  cursor: pointer;
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 0.5rem;
}

.drawer-kpi-option:hover:not(.disabled) {
  border-color: hsl(var(--dashboard-accent) / 0.5);
  background: hsl(var(--dashboard-bg) / 0.5);
}

.drawer-kpi-option.selected {
  background: hsl(var(--dashboard-accent) / 0.15);
  border-color: hsl(var(--dashboard-accent));
  box-shadow: 0 0 0.25rem hsl(var(--dashboard-accent) / 0.2);
}

.drawer-kpi-option.selected::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: 0.5rem;
  background: hsl(var(--dashboard-accent) / 0.05);
  pointer-events: none;
}

.drawer-kpi-option.disabled {
  opacity: 0.4;
  cursor: not-allowed;
}

.drawer-kpi-option-label {
  font-size: 0.75rem;
  font-weight: 500;
  line-height: 1.2;
  flex: 1;
}

.drawer-kpi-option.selected .drawer-kpi-option-label {
  color: hsl(var(--dashboard-accent));
}

.drawer-kpi-option:not(.selected) .drawer-kpi-option-label {
  color: hsl(var(--dashboard-text));
}

.drawer-kpi-option-checkbox {
  width: 1rem;
  height: 1rem;
  border-radius: 50%;
  border: 2px solid hsl(var(--dashboard-border) / 0.5);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: all 0.2s;
}

.drawer-kpi-option-checkbox.checked {
  background: hsl(var(--dashboard-accent));
  border-color: hsl(var(--dashboard-accent));
  color: hsl(var(--dashboard-bg));
}

.drawer-kpi-selector-footer {
  padding: 0.75rem;
  border-top: 1px solid hsl(var(--dashboard-border) / 0.3);
  background: hsl(var(--dashboard-bg) / 0.3);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  flex-shrink: 0;
}

.drawer-kpi-selector-footer-left {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.drawer-kpi-selector-preview {
  display: flex;
  align-items: center;
  gap: 0;
}

.drawer-kpi-preview-item {
  width: 1.25rem;
  height: 1.25rem;
  border-radius: 50%;
  background: hsl(var(--dashboard-accent) / 0.2);
  border: 2px solid hsl(var(--dashboard-card));
  display: flex;
  align-items: center;
  justify-content: center;
  margin-left: -0.25rem;
}

.drawer-kpi-preview-item:first-child {
  margin-left: 0;
}

.drawer-kpi-preview-item span {
  font-size: 0.5rem;
  font-weight: 700;
  color: hsl(var(--dashboard-accent));
}

.drawer-kpi-preview-more {
  background: hsl(var(--dashboard-accent));
}

.drawer-kpi-preview-more span {
  color: hsl(var(--dashboard-bg));
}

.drawer-kpi-selector-preview-text {
  font-size: 0.75rem;
  color: hsl(var(--dashboard-text-muted));
}

.drawer-kpi-selector-clear {
  display: flex;
  align-items: center;
  gap: 0.25rem;
  padding: 0.25rem 0.5rem;
  border-radius: 0.375rem;
  background: transparent;
  border: none;
  color: hsl(var(--color-red));
  cursor: pointer;
  font-size: 0.625rem;
  transition: all 0.2s;
}

.drawer-kpi-selector-clear:hover {
  background: hsl(var(--color-red) / 0.1);
  color: hsl(var(--color-red-light));
}

.drawer-kpi-selector-footer-right {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.drawer-kpi-selector-cancel,
.drawer-kpi-selector-apply {
  padding: 0.375rem 1rem;
  border-radius: 0.375rem;
  font-size: 0.75rem;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.2s;
  border: 1px solid;
  display: flex;
  align-items: center;
  gap: 0.25rem;
}

.drawer-kpi-selector-cancel {
  background: transparent;
  border-color: hsl(var(--dashboard-border));
  color: hsl(var(--dashboard-text));
}

.drawer-kpi-selector-cancel:hover {
  background: hsl(var(--dashboard-bg));
}

.drawer-kpi-selector-apply {
  background: hsl(var(--dashboard-accent));
  border-color: hsl(var(--dashboard-accent));
  color: hsl(var(--dashboard-bg));
  box-shadow: 0 0 0.5rem hsl(var(--dashboard-accent) / 0.3);
}

.drawer-kpi-selector-apply:hover {
  background: hsl(var(--dashboard-accent) / 0.9);
}



/* ============================================
   Module: responsive.css
   ============================================ */

/* Responsive */
@media (max-width: 768px) {
  .campaign-drawer-content {
    max-width: 100vw;
  }
  
  .campaign-drawer-kpi-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  
  .campaign-drawer-charts-grid {
    grid-template-columns: 1fr;
  }
  
  .campaign-drawer-demographics-grid {
    grid-template-columns: 1fr;
  }

  .drawer-kpi-selector-content {
    max-width: 95vw;
    max-height: 90vh;
    height: 90vh;
  }

  .drawer-kpi-selector-sidebar {
    width: 8rem;
  }

  .drawer-kpi-selector-grid {
    grid-template-columns: 1fr;
  }
}
