/* ============================================
   MOTION SYSTEM
   GPU-accelerated, 60fps animations
   ============================================ */

:root {
  /* ============================================
     COLOR SYSTEM - Semantic tokens
     ============================================ */

  /* Base colors - Light mode defaults */
  --bg-color: #FFFFFF;
  --bg-color-rgb: 255, 255, 255;
  --bg-secondary: #f7f7f7;
  --bg-tertiary: #f0f0f0;
  --text-color: #1a1a1a;
  --text-muted: #6b7280;
  --text-tertiary: #9ca3af;
  --border-color: #e5e7eb;
  --border-subtle: #f0f0f0;
  --highlight: #007bff;

  /* Surface colors - for elevated elements */
  --surface-default: var(--bg-color);
  --surface-elevated: var(--bg-secondary);
  --surface-overlay: rgba(0, 0, 0, 0.5);

  /* Interactive states */
  --hover-bg: rgba(0, 0, 0, 0.04);
  --active-bg: rgba(0, 0, 0, 0.08);
  --focus-ring: rgba(0, 123, 255, 0.25);

  /* ============================================
     TYPOGRAPHY SYSTEM
     ============================================ */
  --font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  --font-mono: "SF Mono", SFMono-Regular, Consolas, "Liberation Mono", Menlo, monospace;

  /* Type scale - standardized */
  --text-xs: 0.75rem;     /* 12px */
  --text-sm: 0.8125rem;   /* 13px */
  --text-base: 0.875rem;  /* 14px */
  --text-md: 1rem;        /* 16px */
  --text-lg: 1.125rem;    /* 18px */
  --text-xl: 1.25rem;     /* 20px */
  --text-2xl: 1.5rem;     /* 24px */
  --text-3xl: 2rem;       /* 32px */

  /* Line heights */
  --leading-tight: 1.25;
  --leading-normal: 1.5;
  --leading-relaxed: 1.625;

  /* Letter spacing */
  --tracking-tight: -0.01em;
  --tracking-normal: 0;
  --tracking-wide: 0.02em;

  /* Font weights */
  --font-light: 300;
  --font-normal: 400;
  --font-medium: 500;
  --font-semibold: 600;

  /* ============================================
     SPACING SYSTEM - Extended scale
     ============================================ */
  --spacing-xs: 0.25rem;   /* 4px */
  --spacing-sm: 0.5rem;    /* 8px */
  --spacing-md: 0.75rem;   /* 12px */
  --spacing-lg: 1rem;      /* 16px */
  --spacing-xl: 1.5rem;    /* 24px */
  --spacing-2xl: 2rem;     /* 32px */
  --spacing-3xl: 3rem;     /* 48px */

  /* ============================================
     LAYOUT SYSTEM
     ============================================ */
  --panel-inset: 10px;
  --panel-gap: var(--spacing-xl);
  --sidebar-width: 200px;
  --sidebar-collapsed: 72px;
  --sidebar-expanded: 320px;
  --right-sidebar-width: 390px;

  /* ============================================
     BORDER RADIUS - Extended scale
     ============================================ */
  --radius-xs: 4px;
  --radius-sm: 6px;
  --radius-md: 8px;
  --radius-lg: 12px;
  --radius-xl: 16px;
  --radius-full: 9999px;

  /* ============================================
     BUTTON SIZES - Standardized
     ============================================ */
  --btn-height-sm: 32px;
  --btn-height-md: 40px;
  --btn-height-lg: 48px;
  --btn-padding-sm: 0 var(--spacing-md);
  --btn-padding-md: 0 var(--spacing-lg);
  --btn-padding-lg: 0 var(--spacing-xl);

  /* ============================================
     TIMING & EASING
     ============================================ */
  --ease-out: cubic-bezier(0.25, 0.46, 0.45, 0.94);
  --ease-in-out: cubic-bezier(0.4, 0, 0.2, 1);

  --duration-instant: 100ms;
  --duration-fast: 150ms;
  --duration-normal: 250ms;
  --duration-slow: 400ms;

  /* ============================================
     EFFECTS
     ============================================ */
  --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.05);
  --shadow-md: 0 4px 12px rgba(0, 0, 0, 0.1);
  --shadow-lg: 0 8px 24px rgba(0, 0, 0, 0.15);
  --shadow-xl: 0 12px 48px rgba(0, 0, 0, 0.2);

  /* Noise texture as data URI */
  --noise-texture: url("data:image/svg+xml,%3Csvg viewBox='0 0 150 150' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='1.32' numOctaves='1' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* Reduce motion for users who prefer it */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}

/* Disable text selection highlight */
::selection {
  background: transparent;
}

::-moz-selection {
  background: transparent;
}

/* Custom color utilities */
.text-purple {
  color: #6f42c1 !important;
}

/* ============================================
   LOADING UTILITIES
   Reusable loading states
   ============================================ */

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

@keyframes pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.5; }
}

/* Spinning icon - add to any icon */
.is-loading .bi-arrow-clockwise,
.is-loading .bi-arrow-repeat,
.icon-spin {
  animation: spin 1s linear infinite;
}

/* Pulsing content - add .is-loading to parent */
.is-loading {
  pointer-events: none;
}

/* Button loading state */
.btn.is-loading {
  opacity: 0.7;
  cursor: wait;
}


/* Artist switcher item loading state */
.artist-switcher-item.is-switching {
  opacity: 0.5;
  pointer-events: none;
  position: relative;
}

.artist-switcher-item.is-switching::after {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  width: 20px;
  height: 20px;
  margin: -10px 0 0 -10px;
  border: 2px solid rgba(255,255,255,0.3);
  border-top-color: #fff;
  border-radius: 50%;
  animation: spin 0.6s linear infinite;
}

/* ============================================
   GENERAL STYLING
   ============================================ */

html {
  background-color: var(--bg-secondary);
}

html, body {
  overflow-x: hidden;
  max-width: 100%;
  overscroll-behavior-x: none; /* Prevent browser back/forward swipe navigation */
}

body {
  font-family: var(--font-sans);
  font-size: var(--text-base);
  line-height: var(--leading-normal);
  letter-spacing: var(--tracking-normal);
  background-color: var(--bg-secondary);
  color: var(--text-color);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  overflow: hidden;
}

/* Headings */
h1, .h1,
h2, .h2,
h3, .h3,
h4, .h4,
h5, .h5,
h6, .h6 {
  font-weight: 600;
  line-height: var(--leading-tight);
  letter-spacing: var(--tracking-tight);
  color: var(--text-color);
}

h1, .h1 { font-size: var(--text-3xl); }
h2, .h2 { font-size: var(--text-2xl); }
h3, .h3 { font-size: var(--text-xl); }
h4, .h4 { font-size: var(--text-lg); }
h5, .h5 { font-size: var(--text-md); }
h6, .h6 { font-size: var(--text-base); }

/* Paragraph spacing */
p {
  margin-bottom: 1rem;
}

p:last-child {
  margin-bottom: 0;
}

/* Small text */
small, .small, .text-sm {
  font-size: var(--text-sm);
}

/* Muted text */
.text-muted {
  color: var(--text-muted) !important;
}

/* Page content fade-in on load */
@keyframes contentFadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

main.main-content > *:not(.top-bar):not(.alert) {
  animation: contentFadeIn var(--duration-slow) var(--ease-out) both;
}

/* Alert fade-in */
.alert {
  animation: contentFadeIn var(--duration-normal) var(--ease-out) both;
}

/* Button transitions */
.btn {
  transition:
    background-color var(--duration-fast) var(--ease-out),
    border-color var(--duration-fast) var(--ease-out),
    color var(--duration-fast) var(--ease-out),
    box-shadow var(--duration-fast) var(--ease-out),
    transform var(--duration-instant) var(--ease-out);
}

.btn:hover:not(:disabled) {
  opacity: 0.9;
  transform: translateY(-1px);
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.1);
}

.btn:active:not(:disabled) {
  opacity: 1;
  transform: translateY(0) scale(0.97);
  box-shadow: none;
}

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

/* Section 2: Button loading states with spinners */
.btn.is-loading {
  position: relative;
  color: transparent !important;
  pointer-events: none;
  cursor: wait;
}

.btn.is-loading::after {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  width: 1em;
  height: 1em;
  margin: -0.5em 0 0 -0.5em;
  border: 2px solid currentColor;
  border-right-color: transparent;
  border-radius: 50%;
  animation: spin 0.6s linear infinite;
  opacity: 1;
}

.btn.is-loading > * {
  visibility: hidden;
}

/* Preserve button color for spinner */
.btn-primary.is-loading::after {
  border-color: #fff;
  border-right-color: transparent;
}

.btn-outline-primary.is-loading::after,
.btn-outline-secondary.is-loading::after {
  border-color: currentColor;
  border-right-color: transparent;
}

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

/* View toggle and action buttons - consistent height */
.view-toggle .btn,
.btn-action {
  height: var(--btn-height-sm);
  padding: var(--btn-padding-sm);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--spacing-sm);
  font-size: 0.875rem;
  line-height: 1;
}

.btn-action i {
  font-size: 0.875rem;
}

/* Prevent content overflow */
*, *::before, *::after {
  box-sizing: border-box;
}

img, video, iframe {
  max-width: 100%;
  height: auto;
}

pre, code {
  word-wrap: break-word;
  overflow-wrap: break-word;
  font-family: inherit;
}

/* Monospace - use for code only */
code,
pre,
kbd,
samp,
.font-monospace {
  font-family: var(--font-mono);
  font-size: 0.9em;
}

@media (max-width: 899.98px) {
  pre {
    white-space: pre-wrap;
    font-size: 0.75rem;
  }

  .card {
    margin-left: 0;
    margin-right: 0;
  }

  .table {
    font-size: 0.8rem;
  }

  .btn-group {
    flex-wrap: wrap;
    gap: 0.25rem;
  }

  h1, .h1 { font-size: var(--text-2xl); }
  h2, .h2 { font-size: var(--text-xl); }
  h3, .h3 { font-size: var(--text-lg); }
}

/* ============================================
   SECTION 3: SKELETON LOADERS
   Synchronized sweep animation for all skeletons
   ============================================ */

/* List row skeleton */
.list-row-skeleton {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: var(--spacing-md) var(--spacing-lg);
  background: var(--bg-color);
  border-radius: var(--radius-sm);
  pointer-events: none;
}

.list-row-skeleton-image {
  width: 48px;
  height: 48px;
  flex-shrink: 0;
  border-radius: 6px;
  background: linear-gradient(90deg, var(--bg-secondary) 0%, var(--border-color) 50%, var(--bg-secondary) 100%);
  background-size: 200% 100%;
  animation: shimmer 2.5s linear infinite;
}

.list-row-skeleton-content {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.list-row-skeleton-title {
  height: 1rem;
  width: 60%;
  border-radius: 4px;
  background: linear-gradient(90deg, var(--bg-secondary) 0%, var(--border-color) 50%, var(--bg-secondary) 100%);
  background-size: 200% 100%;
  animation: shimmer 2.5s linear infinite;
}

.list-row-skeleton-subtitle {
  height: 0.75rem;
  width: 40%;
  border-radius: 4px;
  background: linear-gradient(90deg, var(--bg-secondary) 0%, var(--border-color) 50%, var(--bg-secondary) 100%);
  background-size: 200% 100%;
  animation: shimmer 2.5s linear infinite;
}

.list-row-skeleton-action {
  width: 40px;
  height: 22px;
  border-radius: 11px;
  background: linear-gradient(90deg, var(--bg-secondary) 0%, var(--border-color) 50%, var(--bg-secondary) 100%);
  background-size: 200% 100%;
  animation: shimmer 2.5s linear infinite;
}

/* Grid card skeleton */
.grid-card-skeleton {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  pointer-events: none;
}

.grid-card-skeleton-image {
  width: 100%;
  aspect-ratio: 1;
  border-radius: 6px;
  background: linear-gradient(90deg, var(--bg-secondary) 0%, var(--border-color) 50%, var(--bg-secondary) 100%);
  background-size: 200% 100%;
  animation: shimmer 2.5s linear infinite;
}

.grid-card-skeleton-content {
  display: flex;
  flex-direction: column;
  gap: 0.375rem;
  padding: var(--spacing-sm) 0;
}

.grid-card-skeleton-title {
  height: 1rem;
  width: 75%;
  border-radius: 4px;
  background: linear-gradient(90deg, var(--bg-secondary) 0%, var(--border-color) 50%, var(--bg-secondary) 100%);
  background-size: 200% 100%;
  animation: shimmer 2.5s linear infinite;
}

.grid-card-skeleton-subtitle {
  height: 0.75rem;
  width: 50%;
  border-radius: 4px;
  background: linear-gradient(90deg, var(--bg-secondary) 0%, var(--border-color) 50%, var(--bg-secondary) 100%);
  background-size: 200% 100%;
  animation: shimmer 2.5s linear infinite;
}

/* ============================================
   UTILITY CLASSES
   Avatar sizes and common patterns
   ============================================ */

.avatar-sm {
  width: 36px;
  height: 36px;
  object-fit: cover;
}

.avatar-md {
  width: 40px;
  height: 40px;
  object-fit: cover;
}

.qr-thumb {
  width: 40px;
  height: 40px;
  cursor: pointer;
}

/* ============================================
   TOP BAR
   ============================================ */

.top-bar {
  position: fixed;
  top: var(--panel-inset);
  left: calc(var(--panel-inset) + var(--sidebar-collapsed) + var(--panel-gap));
  right: var(--panel-inset);
  z-index: 100;
  display: flex;
  align-items: center;
  gap: 1rem;
  height: 60px;
  padding: 0 1rem;
  background: transparent;
  transition: transform 0.3s ease, right 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

/* Contract top bar when sidebar is open */
body.right-sidebar-open .top-bar {
  right: calc(var(--panel-inset) + var(--right-sidebar-width) + var(--panel-gap));
}

/* Right slot - page actions and user menu */
.top-bar-right {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  flex-shrink: 0;
}

.top-bar.is-hidden {
  transform: translateY(-100%);
}

/* Calendar page: hide top bar entirely (calendar has its own controls) */
.page-calendar .top-bar {
  display: none;
}

/* Calendar page: 10px gaps from browser edge, full-width by default */
body.page-calendar main.main-content {
  left: calc(var(--panel-inset) + var(--sidebar-collapsed) + var(--panel-inset));
  right: var(--panel-inset);
}

/* Contract calendar when right sidebar is open */
body.page-calendar.right-sidebar-open main.main-content {
  right: calc(var(--panel-inset) + var(--right-sidebar-width) + var(--panel-inset));
}

body.page-calendar .main-content-inner {
  padding: 0;
}

/* Collapsed sidebar (900px - 1400px): same behavior */
@media (max-width: 1600px) {
  body.page-calendar main.main-content {
    left: calc(var(--panel-inset) + var(--sidebar-collapsed) + var(--panel-inset));
    right: var(--panel-inset);
  }

  body.page-calendar.right-sidebar-open main.main-content {
    right: calc(var(--panel-inset) + var(--right-sidebar-width) + var(--panel-gap));
  }
}

/* Mobile (< 900px): no sidebar, 10px from both edges */
@media (max-width: 899.98px) {
  body.page-calendar main.main-content {
    left: var(--panel-inset);
    right: var(--panel-inset);
  }
}

/* Top bar search - hidden by default, shown on searchable pages */
.top-bar-search {
  display: none;
  flex: 1;
  align-items: center;
  gap: 0.5rem;
  height: 44px;
  min-width: 150px;
  max-width: 600px;
  padding: 0 1rem;
  border-radius: 50px;
  border: 1px solid var(--border-color);
  transition: border-color 0.3s ease, opacity 0.3s ease;
}

.top-bar-search.is-faded {
  opacity: 0.1;
  pointer-events: none;
}

/* Light mode - border matches text/icon */
[data-theme="light"] .top-bar-search {
  border-color: #aaaaaa;
}

/* Fade lighter when scrolling */
.top-bar-search.is-scrolled i,
.top-bar-search.is-scrolled input {
  color: #666666;
}

.top-bar-search.is-scrolled {
  border-color: #666666;
}

.top-bar-search.is-scrolled input::placeholder {
  color: #888888;
}

[data-theme="light"] .top-bar-search.is-scrolled,
[data-theme="light"] .top-bar-search.is-scrolled i,
[data-theme="light"] .top-bar-search.is-scrolled input {
  border-color: #cccccc;
  color: #cccccc;
}

[data-theme="light"] .top-bar-search.is-scrolled input::placeholder {
  color: #dddddd;
}

/* Show search only on searchable pages - use !important to override inline styles from SPA navigation */
.page-artists .top-bar-search,
.page-releases .top-bar-search,
.page-fans .top-bar-search {
  display: flex !important;
}

/* Searchable pages: centered search bar with actions on right */
.page-artists .top-bar,
.page-releases .top-bar {
  justify-content: center;
}

.page-artists .top-bar-search,
.page-releases .top-bar-search {
  flex: 0 1 400px;
  margin: 0;
}

.page-artists .top-bar-right,
.page-releases .top-bar-right {
  position: absolute;
  right: 1rem;
}

.top-bar-search i {
  color: var(--text-muted);
  font-size: var(--text-base);
  transition: color 0.1s ease;
}

.top-bar-search input {
  flex: 1;
  border: none;
  background: transparent;
  font-size: var(--text-base);
  color: var(--text-color);
  outline: none;
  min-width: 0;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  transition: color 0.1s ease;
}

.top-bar-search input::placeholder {
  color: var(--text-muted);
}

.top-bar-search input::selection {
  background: rgba(72, 219, 251, 0.3);
  color: inherit;
}

[data-theme="light"] .top-bar-search input::selection {
  background: rgba(72, 219, 251, 0.4);
}

/* Light scheme - lighter grey for visibility over varied backgrounds */
[data-theme="light"] .top-bar-search i,
[data-theme="light"] .top-bar-search input {
  color: #999999;
  transition: color 0.1s ease;
}

[data-theme="light"] .top-bar-search input::placeholder {
  color: #aaaaaa;
}

/* Iridescent border when search has content */
.top-bar-search {
  position: relative;
  z-index: 1;
}

/* Gradient border using mask technique - outline only */
.top-bar-search::before {
  content: '';
  position: absolute;
  inset: -2px;
  border-radius: 52px;
  background: conic-gradient(
    from var(--glow-angle, 0deg),
    #48dbfb,
    #4ade80,
    #48dbfb,
    #54a0ff,
    #ff9ff3,
    #54a0ff,
    #48dbfb
  );
  -webkit-mask:
    linear-gradient(#fff 0 0) content-box,
    linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  padding: 2px;
  opacity: 0;
  transition: opacity 0.6s ease;
  pointer-events: none;
}

/* Show border when has content - muted when idle */
.top-bar-search.has-content::before {
  opacity: 1;
  animation: searchGlowRotate 4s linear infinite;
  filter: saturate(0.5) brightness(0.7);
  transition: filter 0.8s ease-out;
}

/* Full vibrancy when actively typing */
.top-bar-search.has-content.is-typing::before {
  filter: saturate(1) brightness(1);
  transition: filter 0.1s ease-out;
}


/* Dark mode - fade lighter */
.top-bar-search.has-content i,
.top-bar-search.has-content input {
  color: #ffffff;
}

/* Light mode - lighter grey for visibility over varied backgrounds */
[data-theme="light"] .top-bar-search.has-content i,
[data-theme="light"] .top-bar-search.has-content input {
  color: #888888;
  transition: color 0.1s ease;
}

/* Light mode - fade darker when typing */
[data-theme="light"] .top-bar-search.is-typing i,
[data-theme="light"] .top-bar-search.is-typing input {
  color: var(--text-color);
  transition: color 0.1s ease;
}

@keyframes searchGlowRotate {
  from { --glow-angle: 0deg; }
  to { --glow-angle: 360deg; }
}

/* Register the custom property for animation */
@property --glow-angle {
  syntax: '<angle>';
  initial-value: 0deg;
  inherits: false;
}

/* Collapsed sidebar - allow search to expand more */
@media (max-width: 1600px) {
  .top-bar-search {
    max-width: 100%;
  }
}

@media (max-width: 899.98px) {
  .top-bar-search {
    display: none !important;
  }
}

/* Page title in top bar */
.top-bar-title {
  display: flex;
  align-items: center;
  height: 36px;
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--text-color);
  background: var(--bg-color);
  padding: 0 1rem;
  border-radius: 50px;
  margin: 0;
  white-space: nowrap;
}

/* ============================================
   TOP BAR PAGE ACTIONS (inside top bar)
   ============================================ */

.top-bar-page-actions {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.top-bar-action-btn {
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-sm);
  height: var(--btn-height-md);
  padding: var(--btn-padding-md);
  font-size: var(--text-sm);
  font-weight: var(--font-medium);
  color: var(--bg-color);
  background: var(--text-color);
  border: none;
  border-radius: var(--radius-full);
  text-decoration: none;
  white-space: nowrap;
  transition: all var(--duration-fast) ease;
}

[data-theme="dark"] .top-bar-action-btn {
  color: var(--bg-color);
  background: var(--text-color);
}

.top-bar-action-btn:hover {
  opacity: 0.9;
  color: var(--bg-color);
}

[data-theme="dark"] .top-bar-action-btn:hover {
  color: var(--bg-color);
}

.top-bar-action-btn i {
  font-size: var(--text-base);
}

/* Legacy page actions bar - keep for backwards compatibility */
.page-actions-bar {
  position: fixed;
  top: var(--panel-inset);
  right: calc(var(--panel-inset) + var(--right-sidebar-width) + var(--panel-gap) + var(--spacing-lg));
  height: 60px;
  display: flex;
  align-items: center;
  gap: var(--spacing-md);
  z-index: 200;
  pointer-events: auto;
}

.page-actions-left {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
}

/* View toggle pill */
.view-toggle-pill {
  display: flex;
  align-items: center;
  background: var(--bg-secondary);
  border-radius: 8px;
  padding: 3px;
  gap: 2px;
}

.view-toggle-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 30px;
  border: none;
  background: transparent;
  color: var(--text-muted);
  border-radius: 6px;
  cursor: pointer;
  transition: all 0.15s ease;
}

.view-toggle-btn:hover {
  color: var(--text-color);
  background: var(--bg-tertiary);
}

.view-toggle-btn.active {
  color: var(--text-color);
  background: var(--bg-color);
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}

/* Sort dropdown */
.sort-dropdown {
  position: relative;
}

.sort-dropdown-btn {
  display: flex;
  align-items: center;
  gap: 0.375rem;
  height: 36px;
  padding: 0 1rem;
  border: none;
  background: #1a1a1a;
  color: #fff;
  border-radius: 50px;
  cursor: pointer;
  font-size: var(--text-sm);
  font-weight: 500;
  transition: all 0.15s ease;
}

[data-theme="dark"] .sort-dropdown-btn {
  color: #111;
  background: #fff;
}

.sort-dropdown-btn:hover {
  opacity: 0.85;
}

[data-theme="dark"] .sort-dropdown-btn:hover {
  color: #111;
}

.sort-dropdown-btn i {
  font-size: 0.875rem;
}

.sort-dropdown-menu {
  position: absolute;
  top: calc(100% + 4px);
  right: 0;
  min-width: 150px;
  background: var(--bg-color);
  border: 1px solid var(--border-color);
  border-radius: 8px;
  padding: 4px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
  opacity: 0;
  visibility: hidden;
  transform: translateY(-4px);
  transition: all 0.15s ease;
  z-index: 100;
}

.sort-dropdown.is-open .sort-dropdown-menu {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.sort-dropdown-item {
  display: block;
  width: 100%;
  padding: 8px 12px;
  border: none;
  background: transparent;
  color: var(--text-muted);
  font-size: var(--text-sm);
  text-align: left;
  border-radius: 6px;
  cursor: pointer;
  transition: all 0.1s ease;
}

.sort-dropdown-item:hover {
  background: var(--bg-secondary);
  color: var(--text-color);
}

.sort-dropdown-item.active {
  color: var(--text-color);
  font-weight: 500;
}

/* Page action button (Add Artist etc.) */
.page-action-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  height: 36px;
  padding: 0 1rem;
  background: var(--text-color);
  color: var(--bg-color);
  border: none;
  border-radius: 8px;
  font-size: var(--text-sm);
  font-weight: 500;
  text-decoration: none;
  cursor: pointer;
  transition: all 0.15s ease;
}

.page-action-btn:hover {
  opacity: 0.9;
  color: var(--bg-color);
}

.page-action-btn i {
  font-size: 0.875rem;
}

/* Hide list view toggle on desktop (grid only) */
@media (min-width: 769px) {
  .view-toggle-pill {
    display: none;
  }
}

/* Collapsed sidebar positioning */
@media (max-width: 1600px) {
  .page-actions-bar {
    right: calc(var(--panel-inset) + var(--right-sidebar-width) + var(--panel-gap) + 1rem);
  }
}

/* Mobile - hide page actions (use floating UI instead) */
@media (max-width: 899.98px) {
  .page-actions-bar {
    display: none;
  }
  .top-bar-page-actions {
    display: none;
  }
}

/* ============================================
   FLOATING ACTION BUTTON (FAB) — site-wide
   ============================================ */

.page-fab {
  position: fixed;
  bottom: 2rem;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 0.25rem;
  background: var(--bg-color);
  border: 1px solid var(--border-color);
  border-radius: 2rem;
  padding: 0.375rem;
  box-shadow: 0 4px 16px rgba(0,0,0,0.12);
  z-index: 100;
}

.page-fab .btn {
  border: none;
  background: transparent;
  width: 36px;
  height: 36px;
  padding: 0;
  border-radius: 50%;
  font-size: 1rem;
  color: var(--text-color);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background-color 0.15s ease;
}

.page-fab .btn:hover {
  background: var(--bg-secondary);
}

.page-fab .btn-primary {
  background: var(--text-color);
  color: var(--bg-color);
}

.page-fab .btn-primary:hover {
  background: #333;
}

.page-fab .fab-divider {
  width: 1px;
  height: 24px;
  background: var(--border-color);
}

/* Single FAB button (no container needed) */
.fab-single {
  position: fixed;
  bottom: 2rem;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  background: var(--text-color);
  color: var(--bg-color);
  border: none;
  border-radius: 2rem;
  padding: 0.75rem 1.5rem;
  font-size: 0.875rem;
  font-weight: 500;
  box-shadow: 0 4px 16px rgba(0,0,0,0.15);
  z-index: 100;
  cursor: pointer;
  transition: transform 0.15s ease, box-shadow 0.15s ease;
}

.fab-single:hover {
  transform: translateX(-50%) translateY(-2px);
  box-shadow: 0 6px 20px rgba(0,0,0,0.2);
}

.fab-single i {
  font-size: 1rem;
}

/* FAB danger variant */
.fab-single.fab-danger {
  background: #dc3545;
  color: #fff;
}

.fab-single.fab-danger:hover {
  background: #bb2d3b;
}

[data-theme="dark"] .fab-single.fab-danger {
  background: #dc3545;
  color: #fff;
}

/* Dark mode FAB styles */
[data-theme="dark"] .page-fab .btn:hover {
  background: rgba(255,255,255,0.1);
}

[data-theme="dark"] .page-fab .btn-primary {
  background: #fff;
  color: #111;
}

[data-theme="dark"] .fab-single {
  background: #fff;
  color: #111;
}

@media (max-width: 899.98px) {
  .top-bar-title {
    font-size: var(--text-xs);
    max-width: 200px;
    overflow: hidden;
    text-overflow: ellipsis;
    padding: 0 0.75rem;
  }

  .page-fab,
  .fab-single {
    bottom: 1rem;
  }

  .page-fab {
    padding: 0.25rem;
  }

  .fab-single {
    padding: 0.625rem 1.25rem;
  }
}

/* ============================================
   MOBILE MENU TOGGLE
   ============================================ */

/* ============================================
   THEME TOGGLE
   ============================================ */

.theme-toggle {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  padding: 0;
  background: var(--bg-color);
  border: none;
  border-radius: 50%;
  color: var(--text-color);
  cursor: pointer;
  transition: background-color 0.2s ease;
}

.theme-toggle:hover {
  background-color: var(--bg-secondary);
}

.theme-toggle i {
  font-size: 1.1rem;
}

.theme-icon-light {
  display: none;
}

.theme-icon-dark {
  display: block;
}

/* ============================================
   TOP BAR GREETING
   ============================================ */

.top-bar-greeting-container {
  position: relative;
  height: 36px;
  display: flex;
  align-items: center;
}

.top-bar-greeting {
  display: flex;
  align-items: center;
  height: 36px;
  font-size: var(--text-sm);
  font-weight: 500;
  transition: opacity 0.5s ease-out;
  letter-spacing: var(--tracking-wide);
  color: var(--text-color);
  background: var(--bg-color);
  padding: 0 1rem;
  border-radius: 50px;
}

.top-bar-greeting.fade-out {
  opacity: 0;
}

/* ============================================
   PROFILE TOGGLE
   ============================================ */

/* Top bar notification icon */
.top-bar-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  color: var(--text-muted);
  text-decoration: none;
  border-radius: 50%;
  margin-right: 0.5rem;
  background: var(--bg-color);
  border: 1px solid var(--border-color);
  transition: color var(--duration-fast) var(--ease-out), background var(--duration-fast) var(--ease-out);
}

.top-bar-icon:hover {
  color: var(--text-color);
  background: var(--hover-bg);
}

.top-bar-icon i {
  font-size: 1.125rem;
}

.profile-toggle {
  display: flex;
  align-items: center;
  padding: 0;
  color: var(--text-color);
  text-decoration: none;
  border-radius: 50%;
  background: transparent;
  transition:
    background-color var(--duration-fast) var(--ease-out),
    transform var(--duration-instant) var(--ease-out);
}

.profile-toggle:hover {
  opacity: 0.8;
}

.profile-toggle:active {
  transform: scale(0.98);
}

/* ============================================
   THEME TRANSITION
   ============================================ */

html.theme-transitioning,
html.theme-transitioning *,
html.theme-transitioning *::before,
html.theme-transitioning *::after {
  transition: background-color 250ms ease-out, border-color 250ms ease-out, color 250ms ease-out !important;
}

/* Exclude heavy content from theme transitions for performance */
html.theme-transitioning .calendar-grid *,
html.theme-transitioning .calendar-timeline *,
html.theme-transitioning .table tbody *,
html.theme-transitioning .ag-chart * {
  transition: none !important;
}

/* ============================================
   DARK MODE
   ============================================ */

[data-theme="dark"] {
  /* Base colors */
  --bg-color: #131313;
  --bg-color-rgb: 19, 19, 19;
  --bg-secondary: #0a0a0a;
  --bg-tertiary: #1a1a1a;
  --text-color: #FFFFFF;
  --text-muted: #A3A3A3;
  --text-tertiary: #666666;
  --border-color: rgba(255, 255, 255, 0.1);
  --border-subtle: rgba(255, 255, 255, 0.05);
  --highlight: #FFFFFF;

  /* Surface colors */
  --surface-default: var(--bg-color);
  --surface-elevated: #1a1a1a;
  --surface-overlay: rgba(0, 0, 0, 0.7);

  /* Interactive states */
  --hover-bg: rgba(255, 255, 255, 0.04);
  --active-bg: rgba(255, 255, 255, 0.08);
  --focus-ring: rgba(255, 255, 255, 0.15);

  /* Shadows for dark mode */
  --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.2);
  --shadow-md: 0 4px 12px rgba(0, 0, 0, 0.3);
  --shadow-lg: 0 8px 24px rgba(0, 0, 0, 0.4);
  --shadow-xl: 0 12px 48px rgba(0, 0, 0, 0.5);
}


[data-theme="dark"] .sidebar .nav-link:hover,
[data-theme="dark"] .sidebar .nav-link.active {
  background-color: var(--hover-bg);
}

[data-theme="dark"] .theme-toggle:hover {
  background-color: var(--hover-bg);
}


[data-theme="dark"] .theme-icon-light {
  display: block;
}

[data-theme="dark"] .theme-icon-dark {
  display: none;
}

[data-theme="dark"] .card {
  background-color: var(--surface-elevated);
  border: 1px solid var(--border-subtle);
}

[data-theme="dark"] .card-header {
  background-color: transparent;
  border-bottom: 1px solid var(--border-subtle);
}

[data-theme="dark"] .table {
  --bs-table-color: var(--text-color);
  --bs-table-bg: transparent;
  --bs-table-border-color: var(--border-color);
  --bs-table-striped-bg: transparent;
  --bs-table-striped-color: var(--text-color);
  --bs-table-hover-bg: rgba(255, 255, 255, 0.05);
  --bs-table-hover-color: var(--text-color);
  color: var(--text-color);
}

[data-theme="dark"] .table th,
[data-theme="dark"] .table td {
  color: var(--text-color);
  border-bottom-color: var(--border-color);
}

[data-theme="dark"] .table-striped > tbody > tr:nth-of-type(odd),
[data-theme="dark"] .table-striped > tbody > tr:nth-of-type(odd) > * {
  background-color: transparent !important;
  color: var(--text-color) !important;
}

[data-theme="dark"] .table-hover > tbody > tr:hover {
  background-color: rgba(255, 255, 255, 0.05);
}

[data-theme="dark"] .form-control,
[data-theme="dark"] .form-select {
  background-color: var(--bg-color);
  border-color: var(--border-color);
  color: var(--text-color);
}

[data-theme="dark"] .form-control:focus,
[data-theme="dark"] .form-select:focus {
  background-color: var(--bg-color);
  border-color: var(--highlight);
  color: var(--text-color);
  box-shadow: 0 0 0 0.2rem rgba(255, 255, 255, 0.1);
}

[data-theme="dark"] .dropdown-menu {
  background-color: var(--bg-secondary);
  border-color: var(--border-color);
}

[data-theme="dark"] .dropdown-item {
  color: var(--text-color);
}

[data-theme="dark"] .dropdown-item:hover {
  background-color: rgba(255, 255, 255, 0.1);
  color: var(--text-color);
}

[data-theme="dark"] .dropdown-divider {
  border-top-color: var(--border-color);
}

[data-theme="dark"] .settings-panel {
  background-color: var(--bg-secondary);
}

[data-theme="dark"] .settings-panel-header {
  border-bottom-color: var(--border-color);
}

[data-theme="dark"] .settings-panel .nav-link {
  color: var(--text-color);
}

[data-theme="dark"] .settings-panel .nav-link:hover {
  background-color: rgba(255, 255, 255, 0.05);
  color: var(--text-color);
}

[data-theme="dark"] .settings-panel .nav-link.active {
  background-color: rgba(255, 255, 255, 0.1);
  color: var(--text-color);
}

[data-theme="dark"] .settings-panel .form-check-input {
  background-color: #333;
  border-color: #555;
}

[data-theme="dark"] .settings-panel .form-check-input:checked {
  background-color: #0d6efd;
  border-color: #0d6efd;
}

[data-theme="dark"] .alert {
  border-color: var(--border-color);
}

[data-theme="dark"] hr {
  border-color: var(--border-color);
}

[data-theme="dark"] code {
  color: var(--highlight);
  background-color: rgba(255, 255, 255, 0.1);
}

[data-theme="dark"] .badge.bg-secondary {
  background-color: #333 !important;
  color: var(--text-muted);
}

[data-theme="dark"] .badge.bg-primary,
[data-theme="dark"] .badge.bg-success,
[data-theme="dark"] .badge.bg-info {
  background-color: #333 !important;
  color: var(--highlight);
}

[data-theme="dark"] .btn-outline-primary {
  color: var(--highlight);
  border-color: var(--text-muted);
}

[data-theme="dark"] .btn-outline-primary:hover {
  background-color: var(--highlight);
  border-color: var(--highlight);
  color: var(--bg-color);
}

[data-theme="dark"] .btn-primary {
  background-color: var(--highlight);
  border-color: var(--highlight);
  color: var(--bg-color);
}

[data-theme="dark"] .btn-primary:hover {
  background-color: var(--text-muted);
  border-color: var(--text-muted);
}

[data-theme="dark"] a {
  color: var(--highlight);
}

[data-theme="dark"] a:hover {
  color: var(--highlight);
}

[data-theme="dark"] .form-label {
  color: var(--text-muted);
}

[data-theme="dark"] .table th {
  color: var(--text-muted) !important;
}

[data-theme="dark"] .page-link {
  background-color: var(--bg-secondary);
  border-color: var(--border-color);
  color: var(--text-color);
}

[data-theme="dark"] .page-link:hover {
  background-color: rgba(255, 255, 255, 0.1);
  color: var(--text-color);
}

[data-theme="dark"] .page-item.active .page-link {
  background-color: var(--highlight);
  border-color: var(--highlight);
  color: var(--bg-color);
}

[data-theme="dark"] .page-item.disabled .page-link {
  background-color: var(--bg-color);
  color: #555;
}

/* ============================================
   SIDEBAR
   ============================================ */

.sidebar {
  position: fixed;
  top: var(--panel-inset);
  bottom: var(--panel-inset);
  left: var(--panel-inset);
  z-index: 250;
  padding: 0;
  width: var(--sidebar-collapsed);
  background-color: var(--bg-color);
  border-radius: var(--radius-lg);
  overflow: visible;
}

/* Disable sidebar transition when preview is expanded to prevent flicker */
body.preview-expanded .sidebar {
  transition: none;
}

/* Hide left sidebar in expanded mobile view */
body.preview-expanded:has(.is-mobile-view) .sidebar {
  display: none;
}

/* Sidebar branding */
.sidebar-brand {
  margin: 1rem 0.75rem 1rem 0.75rem;
  padding: 2px;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  background: rgba(0, 0, 0, 0.03);
  border-radius: 50px;
  transition: background 0.15s ease;
}

.sidebar-brand:hover {
  background: rgba(0, 0, 0, 0.06);
}

[data-theme="dark"] .sidebar-brand {
  background: rgba(255, 255, 255, 0.05);
}

[data-theme="dark"] .sidebar-brand:hover {
  background: rgba(255, 255, 255, 0.08);
}

.sidebar-artist-name {
  flex: 1;
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--text-color);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.sidebar-artist-chevron {
  color: var(--text-muted);
  font-size: 0.75rem;
  flex-shrink: 0;
  margin-right: 0.5rem;
  transition: transform 0.2s ease;
}

.sidebar-brand:hover .sidebar-artist-chevron {
  color: var(--text-color);
}

.sidebar-brand:hover .sidebar-artist-name {
  color: var(--text-color);
}

.sidebar .nav-link i {
  font-size: 1.25rem;
  width: 24px;
  text-align: center;
  margin-right: 0.75rem;
  flex-shrink: 0;
}

.sidebar .nav-text {
  font-size: var(--text-sm);
  white-space: nowrap;
}

.sidebar .sidebar-divider {
  margin: 0.5rem 1rem;
}

/* Small screens - sidebar hidden, use bottom tab bar instead */
@media (max-width: 899.98px) {
  .top-bar {
    left: 0;
    padding: 0 1rem;
  }
}

/* Main content area */
/* Fills width by default, contracts when sidebar opens */
/* Mini sidebar mode: spacing-lg (16px) gaps on both sides for balance */
main.main-content {
  position: fixed;
  top: var(--panel-inset);
  bottom: var(--panel-inset);
  left: calc(var(--panel-inset) + var(--sidebar-collapsed) + var(--spacing-lg));
  right: calc(var(--panel-inset) + var(--spacing-sm));
  background-color: transparent;
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: right 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

/* Disable transitions on initial page load to prevent sidebar animation flash */
body.no-transition main.main-content,
body.no-transition .right-sidebar-wrapper,
body.no-transition .top-bar,
body.no-transition .grid-card,
body.no-transition .grid-card-image {
  transition: none !important;
  animation: none !important;
}

/* Contract main content when sidebar is open */
body.right-sidebar-open main.main-content {
  right: calc(var(--panel-inset) + var(--right-sidebar-width) + var(--spacing-lg));
}

.main-content-inner {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  padding: calc(60px + 0.75rem) 0 1rem 0;
  overflow-x: hidden;
  overflow-y: auto;
  overflow-anchor: none; /* Prevent scroll jump during resize */
  scrollbar-width: none; /* Firefox */
  -ms-overflow-style: none; /* IE/Edge */
}

.main-content-inner::-webkit-scrollbar {
  display: none; /* Chrome/Safari */
}

/* Right sidebar - two stacked panels */
/* Hidden by default, slides in when .right-sidebar-open is on body */
.right-sidebar-wrapper {
  position: fixed;
  top: var(--panel-inset);
  right: var(--panel-inset);
  bottom: var(--panel-inset);
  width: var(--right-sidebar-width);
  display: flex;
  flex-direction: column;
  gap: var(--spacing-md);
  z-index: 100;
  transform: translateX(calc(100% + var(--panel-inset)));
  transition: transform 0.35s cubic-bezier(0.4, 0, 0.2, 1) !important;
  will-change: transform;
}

/* Show sidebar when .right-sidebar-open is on body */
body.right-sidebar-open .right-sidebar-wrapper {
  transform: translateX(0);
}

/* Slide out right sidebar below 1300px — but not when expanded (visual editor active) */
@media (max-width: 1299px) {
  .right-sidebar-wrapper:not(.is-expanded) {
    transform: translateX(calc(100% + var(--panel-inset))) !important;
  }

  body.right-sidebar-open:not(.visual-editor-open) main.main-content {
    right: calc(var(--panel-inset) + var(--spacing-sm)) !important;
  }

  body.right-sidebar-open:not(.visual-editor-open) .top-bar {
    right: var(--panel-inset) !important;
  }

  /* Calendar page */
  body.page-calendar.right-sidebar-open main.main-content {
    right: calc(var(--panel-inset) + var(--spacing-sm)) !important;
  }
}

/* Ensure transition works when closing */
.right-sidebar-wrapper:not(.is-expanded) {
  transition: transform 0.35s cubic-bezier(0.4, 0, 0.2, 1) !important;
}

.right-sidebar {
  padding: var(--spacing-md);
  background-color: var(--bg-color);
  border-radius: var(--radius-lg);
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

.right-sidebar-top {
  flex: 1;
  min-height: 0;
}

/* Media player - fixed at bottom right */
.right-sidebar.right-sidebar-bottom {
  display: none; /* Hidden for now */
  position: fixed;
  bottom: var(--panel-inset);
  right: var(--panel-inset);
  width: var(--right-sidebar-width);
  background: #1a1a1a;
  border-radius: var(--radius-lg);
  z-index: 100;
  overflow: hidden;
  padding: 0;
}

/* Media Player - horizontal layout with large artwork */
.media-player {
  display: flex;
  gap: 0;
  height: 100%;
  padding: 6px;
  cursor: pointer;
}

.media-player-artwork {
  width: 88px;
  height: 88px;
  flex-shrink: 0;
  background: var(--bg-secondary);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: visible;
  border-radius: 12px;
  position: relative;
}

.media-player-artwork img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 12px;
}

.media-player-artwork > i {
  font-size: 2rem;
  color: var(--text-muted);
}

.media-player-artwork .progress-ring {
  position: absolute;
  top: 0;
  left: 0;
  width: 88px;
  height: 88px;
  transform: rotate(-90deg);
  pointer-events: none;
}

.media-player-artwork .progress-ring-bg {
  stroke: rgba(255, 255, 255, 0.15);
}

.media-player-artwork .progress-ring-fill {
  stroke: var(--text-color);
  transition: stroke-dashoffset 0.1s linear;
}

.media-player-content {
  flex: 1;
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
  padding: 0 12px;
  min-width: 0;
  gap: 12px;
}

.media-player-info {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 2px;
}

.media-player-title {
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--text-color);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.media-player-artist {
  font-size: var(--text-xs);
  color: var(--text-muted);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.media-player-btn {
  width: 40px;
  height: 40px;
  border: none;
  background: rgba(255, 255, 255, 0.1);
  color: var(--text-color);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background-color var(--duration-fast) var(--ease-out);
  flex-shrink: 0;
}

.media-player-btn:hover {
  background: rgba(255, 255, 255, 0.15);
}

.media-player-btn i {
  font-size: 1.25rem;
}

.media-player-btn-play i {
  margin-left: 2px; /* Offset play icon to appear centered */
}

.media-player-btn-play.is-playing i {
  margin-left: 0;
}

.media-player-btn-play.is-playing i::before {
  content: "\f4c3"; /* bi-pause-fill */
}

.media-player-volume-slider {
  width: 60px;
  height: 4px;
  -webkit-appearance: none;
  appearance: none;
  background: var(--border-color);
  border-radius: 2px;
  cursor: pointer;
}

.media-player-volume-slider::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 12px;
  height: 12px;
  background: var(--text-color);
  border-radius: 50%;
  cursor: pointer;
  box-shadow: 0 1px 3px rgba(0,0,0,0.3);
}

.media-player-volume-slider::-moz-range-thumb {
  width: 12px;
  height: 12px;
  background: var(--text-color);
  border: none;
  border-radius: 50%;
  cursor: pointer;
  box-shadow: 0 1px 3px rgba(0,0,0,0.3);
}

/* Media player - no fade animation */

/* Related Releases Grid (bottom right panel) */
.related-releases {
  height: 100%;
  padding: var(--spacing-sm);
  display: flex;
  flex-direction: column;
}

.related-releases-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-template-rows: repeat(5, 1fr);
  gap: 4px;
  flex: 1;
  min-height: 0;
}

.related-release-item {
  position: relative;
  aspect-ratio: 1;
  border-radius: 4px;
  overflow: hidden;
  cursor: pointer;
  background: var(--bg-secondary);
  transition: transform 0.15s ease-out, box-shadow 0.15s ease-out;
}

.related-release-item:hover {
  transform: scale(1.05);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
  z-index: 1;
}

.related-release-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.related-release-item .placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(145deg, #e0c3fc 0%, #c7ceea 50%, #a1c4fd 100%);
}

.related-release-item .placeholder i {
  font-size: 0.75rem;
  color: rgba(255, 255, 255, 0.7);
}

.related-releases-empty {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  color: var(--text-muted);
  font-size: var(--text-sm);
}

.right-sidebar::-webkit-scrollbar {
  display: none;
}

.right-sidebar-header {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 0.5rem;
  padding-bottom: 0.75rem;
  flex-shrink: 0;
}

/* Sidebar close button */
.sidebar-close-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border: none;
  background: transparent;
  color: var(--text-muted);
  cursor: pointer;
  border-radius: var(--radius-sm);
  transition: all var(--duration-fast) var(--ease-out);
  margin-right: auto;
}

.sidebar-close-btn:hover {
  background: var(--bg-secondary);
  color: var(--text-color);
}

.sidebar-close-btn:active {
  transform: scale(0.95);
}

.right-sidebar-content {
  position: relative;
  flex: 1;
  min-height: 0;
  overflow-y: auto;
  scrollbar-width: none;
  -ms-overflow-style: none;
}

.right-sidebar-content::-webkit-scrollbar {
  display: none;
}

/* Collapse button at top-left of iframe */
.right-sidebar-top {
  position: relative;
}

.iframe-collapse-btn {
  position: absolute;
  top: 12px;
  left: 12px;
  z-index: 10;
  width: 36px;
  height: 36px;
  border: none;
  background: var(--bg-color);
  color: var(--text-muted);
  cursor: pointer;
  border-radius: var(--radius-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
  transition: all var(--duration-fast) var(--ease-out);
  opacity: 0.9;
}

.iframe-collapse-btn:hover {
  background: var(--bg-secondary);
  color: var(--text-color);
  opacity: 1;
}

/* Preview panel - hidden by default, slides in from top */
.right-sidebar-preview {
  flex: 0 0 0;
  min-height: 0;
  overflow: hidden;
  transition: flex 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

/* When preview is active, it takes available space */
.right-sidebar-wrapper.preview-active .right-sidebar-preview {
  flex: 1 1 auto;
  min-height: 300px;
}

/* Stats panels */
.sidebar-stats-panel {
  padding: var(--spacing-lg);
  flex-shrink: 0;
}

.sidebar-stats-header {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--text-muted);
  margin-bottom: var(--spacing-md);
}

.sidebar-stats-header i {
  font-size: 1rem;
}

.sidebar-stats-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--spacing-md);
}

.sidebar-stat {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.sidebar-stat-value {
  font-size: 1.75rem;
  font-weight: 700;
  color: var(--text-color);
  line-height: 1;
}

.sidebar-stat-label {
  font-size: var(--text-xs);
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.sidebar-quick-actions {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.sidebar-quick-action {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.75rem;
  background: var(--bg-color);
  border-radius: var(--radius-sm);
  color: var(--text-color);
  text-decoration: none;
  font-size: var(--text-sm);
  font-weight: 500;
  transition: all var(--duration-fast) var(--ease-out);
}

.sidebar-quick-action:hover {
  background: var(--highlight);
  color: white;
}

.sidebar-quick-action i {
  font-size: 1.125rem;
}

/* Hide stats view when preview content is loaded */
.right-sidebar-content:has(.sidebar-preview-panel) .sidebar-stats-view {
  display: none;
}

/* Show top-bar actions when right sidebar is not open */
body:not(.right-sidebar-open) .top-bar-actions {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

/* Hide top-bar actions when right sidebar is visible */
body.right-sidebar-open .top-bar-actions {
  display: none;
}

/* Always show top-bar actions on mobile */
@media (max-width: 899.98px) {
  .top-bar-actions {
    display: flex;
    align-items: center;
    gap: 0.5rem;
  }
}

/* Neutralise container-fluid inside main-content so all pages share the same gutter */
main.main-content .container-fluid {
  padding-left: 0;
  padding-right: 0;
}

/* At 1600px: Collapse left sidebar but KEEP right sidebar visible */
@media (max-width: 1600px) {
  main.main-content {
    left: calc(var(--panel-inset) + var(--sidebar-collapsed) + var(--spacing-lg));
    right: calc(var(--panel-inset) + var(--spacing-lg));
  }
  .top-bar {
    left: calc(var(--panel-inset) + var(--sidebar-collapsed) + var(--spacing-lg));
    right: calc(var(--panel-inset) + var(--spacing-lg));
  }
  /* Only reserve right sidebar space when sidebar is actually open */
  body.right-sidebar-open main.main-content {
    right: calc(var(--panel-inset) + var(--right-sidebar-width) + var(--spacing-lg));
  }
  body.right-sidebar-open .top-bar {
    right: calc(var(--panel-inset) + var(--right-sidebar-width) + var(--spacing-lg));
  }
}

@media (max-width: 899.98px) {
  main.main-content {
    left: 10px;
    right: 10px;
  }
  .main-content-inner {
    padding: calc(60px + 0.75rem) 0.75rem 0.75rem 0.75rem;
  }
}

.sidebar-sticky {
  position: relative;
  top: 0;
  height: 100%;
  padding-top: 0;
  padding-bottom: 0;
  overflow: visible;
  display: flex;
  flex-direction: column;
}

.sidebar .nav-link {
  position: relative;
  width: auto;
  height: 44px;
  padding: 0 var(--spacing-lg);
  margin: var(--spacing-xs) var(--spacing-md);
  border-radius: var(--radius-sm);
  display: flex;
  align-items: center;
  justify-content: flex-start;
  font-weight: 500;
  color: var(--text-color);
  transition:
    color var(--duration-fast) var(--ease-out),
    background-color var(--duration-fast) var(--ease-out),
    transform var(--duration-instant) var(--ease-out);
}

.sidebar .nav-link i {
  margin-right: 0.75rem;
  flex-shrink: 0;
}

.sidebar .nav-text {
  font-size: var(--text-sm);
  white-space: nowrap;
}

.sidebar .nav-link:hover {
  color: var(--highlight);
  background-color: rgba(0, 123, 255, 0.08);
}

.sidebar .nav-link:active {
  transform: scale(0.95);
}

.sidebar .nav-link.active {
  color: var(--highlight);
  background-color: rgba(0, 123, 255, 0.1);
}

.sidebar .sidebar-divider {
  display: none;
}

/* Collapsed sidebar - always use mini/icon mode */
@media (min-width: 0px) {
  .sidebar {
    width: 72px;
    overflow: visible;
    transition: none; /* Snap instantly at breakpoint to prevent flicker */
  }

  .sidebar .nav-link {
    width: 44px;
    padding: 0;
    margin: 0.25rem auto;
    justify-content: center;
  }

  .sidebar .nav-link i {
    margin-right: 0;
  }

  .sidebar .nav-text {
    display: none;
  }

  /* Tooltip on hover when sidebar is collapsed */
  .sidebar .nav-link {
    position: relative;
  }

  .sidebar .nav-link::after {
    content: attr(title);
    position: absolute;
    left: calc(100% + 12px);
    top: 50%;
    transform: translateY(-50%);
    background: var(--bg-color);
    color: var(--text-color);
    padding: 0.5rem 0.75rem;
    border-radius: var(--radius-sm);
    font-size: 0.8125rem;
    font-weight: 500;
    white-space: nowrap;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.15s ease, visibility 0.15s ease;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
    pointer-events: none;
    z-index: 9999;
  }

  .sidebar .nav-link:hover::after {
    opacity: 1;
    visibility: visible;
  }

  .sidebar-brand {
    margin: 1rem auto 1rem auto;
    padding: 2px;
    justify-content: center;
    width: fit-content;
  }

  .sidebar-artist-name,
  .sidebar-artist-chevron {
    display: none;
  }

  .sidebar-settings {
    padding: 0 0 1rem;
    justify-content: center;
  }

  .btn-settings {
    width: 44px;
    padding: 0;
    justify-content: center;
  }

  .btn-settings i {
    margin-right: 0;
  }

  .btn-settings .nav-text {
    display: none;
  }

  main.main-content {
    left: calc(var(--panel-inset) + var(--sidebar-collapsed) + var(--panel-inset));
  }

  .top-bar {
    left: calc(var(--panel-inset) + var(--sidebar-collapsed) + var(--panel-inset));
  }

  .settings-panel {
    left: calc(var(--panel-inset) + var(--sidebar-collapsed) + var(--panel-inset));
  }
}

/* Sidebar artist panel - popup/modal like settings */
.sidebar-artist-panel {
  position: fixed;
  top: var(--panel-inset);
  left: calc(var(--panel-inset) + var(--sidebar-collapsed) + var(--panel-gap));
  width: 200px;
  max-height: calc(100vh - 2rem);
  background: var(--bg-color);
  border-radius: 16px;
  box-shadow: 0 4px 24px rgba(0, 0, 0, 0.12);
  z-index: 1040;
  padding: 1rem;
  transform: translateX(-12px);
  opacity: 0;
  visibility: hidden;
  transition:
    transform var(--duration-normal) var(--ease-out),
    opacity var(--duration-fast) var(--ease-out),
    visibility var(--duration-normal);
  overflow-y: auto;
}

.sidebar-artist-panel.is-open {
  transform: translateX(0);
  opacity: 1;
  visibility: visible;
}

.sidebar-artist-panel-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 0.75rem;
  padding-bottom: 0.75rem;
  border-bottom: 1px solid var(--border-color);
}

.sidebar-artist-panel-header h6 {
  margin: 0;
  font-size: var(--text-sm);
  font-weight: 600;
}

.sidebar-artist-panel-close {
  background: none;
  border: none;
  padding: 0.25rem;
  color: var(--text-muted);
  cursor: pointer;
  border-radius: 4px;
  transition: color 0.15s ease, background 0.15s ease;
}

.sidebar-artist-panel-close:hover {
  color: var(--text-color);
  background: var(--bg-secondary);
}

/* Organisation/All button in panel */
.sidebar-artist-panel-org {
  display: flex;
  align-items: center;
  gap: 0.625rem;
  width: 100%;
  padding: 0.5rem;
  margin-bottom: 0.75rem;
  border: none;
  border-radius: 8px;
  background: transparent;
  cursor: pointer;
  transition: background 0.15s ease;
}

.sidebar-artist-panel-org:hover {
  background: var(--bg-secondary);
}

.sidebar-artist-panel-org.is-selected {
  background: var(--bg-secondary);
}

.sidebar-artist-panel-org-icon {
  width: 36px;
  height: 36px;
  border-radius: 8px;
  background: var(--bg-secondary);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-muted);
  font-size: 1rem;
  overflow: hidden;
  flex-shrink: 0;
}

.sidebar-artist-panel-org-icon img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.sidebar-artist-panel-org-name {
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--text-color);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.sidebar-artist-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.5rem;
  margin-bottom: 0.75rem;
}

.sidebar-artist-grid-item {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  border: 2px solid transparent;
  background: var(--bg-secondary);
  cursor: pointer;
  transition: transform 0.15s ease, border-color 0.15s ease;
  overflow: hidden;
  flex-shrink: 0;
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

.sidebar-artist-grid-item:hover {
  transform: scale(1.08);
}

.sidebar-artist-grid-item.is-selected {
  border-color: var(--highlight);
}

.sidebar-artist-grid-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 50%;
}

.sidebar-artist-grid-item-placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-muted);
  font-size: 1.25rem;
}

.sidebar-artist-add {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  border: 2px dashed var(--border-color);
  background: transparent;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-muted);
  font-size: 1.25rem;
  cursor: pointer;
  transition: transform 0.15s ease, border-color 0.15s ease, color 0.15s ease;
  flex-shrink: 0;
}

.sidebar-artist-add:hover {
  transform: scale(1.08);
  border-color: var(--text-muted);
  color: var(--text-color);
}

/* Artist panel backdrop */
.sidebar-artist-panel-backdrop {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.3);
  z-index: 1039;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.2s ease, visibility 0.2s ease;
}

.sidebar-artist-panel-backdrop.is-open {
  opacity: 1;
  visibility: visible;
}

/* Rotate chevron when panel is open */
.sidebar-brand.is-open .sidebar-artist-chevron {
  transform: rotate(180deg);
}

.sidebar-artist-chevron {
  transition: transform 0.25s ease;
}

/* Hide the old horizontal artist switcher tray */
.artist-switcher-tray {
  display: none !important;
}

.artist-switcher-backdrop {
  display: none !important;
}

/* Hide the old inline dropdown */
.sidebar-artist-dropdown {
  display: none !important;
}

/* Sidebar always stays mini/icon-only at all breakpoints */

/* Preview sidebar stays fixed at 390px (iPhone width) for accurate mobile preview
   It hides entirely below 900px rather than shrinking */

/* Mobile - hide right sidebar */
@media (max-width: 899.98px) {
  main.main-content {
    right: var(--panel-inset);
  }

  .right-sidebar-wrapper {
    display: none;
  }

  .top-bar {
    right: var(--panel-inset);
  }
}

/* ============================================
   DROPDOWN
   ============================================ */

.dropdown-menu {
  border: 1px solid rgba(0, 0, 0, 0.08);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12);
  border-radius: 12px;
  padding: 0.5rem;
  animation: contentFadeIn var(--duration-fast) var(--ease-out);
}

.dropdown-item {
  border-radius: 8px;
  padding: 0.5rem 0.75rem;
  font-size: var(--text-sm);
  transition:
    background-color var(--duration-fast) var(--ease-out),
    color var(--duration-fast) var(--ease-out);
}

.dropdown-item:hover {
  background-color: rgba(0, 123, 255, 0.08);
}

.dropdown-item:active {
  background-color: #007bff;
}

/* ============================================
   CARDS
   ============================================ */

.card {
  --bs-card-border-radius: var(--radius-md);
  --bs-card-inner-border-radius: calc(var(--radius-md) - 1px);
  margin-bottom: 0.75rem;
  border: none;
  border-radius: var(--radius-md);
  box-shadow: none;
  background-color: var(--bg-color);
  overflow: hidden;
}


.card-header {
  background-color: transparent;
  border-bottom: none;
  font-weight: 600;
  font-size: var(--text-base);
  padding: 0.75rem;
}

/* Card titles */
.card-title {
  font-size: var(--text-md);
  font-weight: 500;
  margin-bottom: 0.5rem;
}

/* Full-height cards - vertically center content */
.card.h-100 > .card-body {
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.card-body {
  padding: 0.75rem;
}

/* Content-heavy cards get extra inset padding */
.card-inset > .card-header,
.card-inset > .card-body {
  padding: 1rem 1.5rem;
}

.card-inset > .card-header {
  padding-bottom: 0.5rem;
}

/* ============================================
   FORMS
   ============================================ */

.form-label {
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--text-muted);
  margin-bottom: 0.375rem;
}

.form-control,
.form-select {
  font-size: var(--text-base);
}

.form-control::placeholder {
  color: #9ca3af;
}

.form-text {
  font-size: var(--text-xs);
  color: var(--text-muted);
}

.required:after {
  content: '*';
  color: red;
  margin-left: 2px;
}

.form-control,
.form-select {
  height: 42px;
  transition:
    border-color var(--duration-fast) var(--ease-out),
    box-shadow var(--duration-fast) var(--ease-out),
    background-color var(--duration-fast) var(--ease-out);
}

.input-group .form-control {
  height: 42px;
}

.input-group .btn {
  height: 42px;
}

/* Section 1: Form focus rings - keyboard-only focus states */
.form-control:focus,
.form-select:focus {
  border-color: #007bff;
  box-shadow: 0 0 0 3px rgba(0, 123, 255, 0.15);
}

.form-control:focus-visible,
.form-select:focus-visible {
  border-color: var(--highlight);
  box-shadow: 0 0 0 3px rgba(0, 123, 255, 0.25);
  outline: 2px solid rgba(0, 123, 255, 0.5);
  outline-offset: 2px;
}

/* Form switch animation */
.form-check-input {
  transition:
    background-color var(--duration-fast) var(--ease-out),
    border-color var(--duration-fast) var(--ease-out),
    background-position var(--duration-fast) var(--ease-out),
    box-shadow var(--duration-fast) var(--ease-out),
    transform var(--duration-instant) var(--ease-out);
  cursor: pointer;
}

.form-check-input:hover {
  transform: scale(1.05);
}

.form-check-input:focus {
  box-shadow: 0 0 0 3px rgba(0, 123, 255, 0.1);
}

.form-check-input:focus-visible {
  box-shadow: 0 0 0 3px rgba(0, 123, 255, 0.25);
  outline: 2px solid rgba(0, 123, 255, 0.5);
  outline-offset: 2px;
}

.form-check-input:active {
  transform: scale(0.92);
}

/* ============================================
   TABLES
   ============================================ */

.table-responsive {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  max-width: 100%;
}

.table {
  font-size: var(--text-sm);
  --bs-table-color: var(--text-color);
  --bs-table-bg: transparent;
  --bs-table-border-color: var(--border-color);
  --bs-table-striped-bg: transparent;
  --bs-table-striped-color: var(--text-color);
  --bs-table-hover-bg: rgba(0, 0, 0, 0.02);
  --bs-table-hover-color: var(--text-color);
  color: var(--text-color);
}

.table th {
  font-weight: 600;
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.03em;
  color: var(--text-muted);
}

.table td,
.table th {
  vertical-align: middle;
  border-bottom-color: var(--border-color);
  padding: var(--spacing-lg) var(--spacing-lg);
}

.table-hover > tbody > tr {
  transition: background-color var(--duration-fast) var(--ease-out);
}

.table-hover > tbody > tr:hover {
  background-color: rgba(0, 0, 0, 0.02);
}

/* Neutralise Bootstrap striped rows — consistent background throughout */
.table-striped > tbody > tr:nth-of-type(odd),
.table-striped > tbody > tr:nth-of-type(odd) > * {
  --bs-table-bg-type: transparent !important;
  --bs-table-accent-bg: transparent !important;
  background-color: transparent !important;
  color: var(--text-color) !important;
}

.table-striped > tbody > tr:nth-of-type(even),
.table-striped > tbody > tr:nth-of-type(even) > * {
  --bs-table-bg-type: transparent !important;
  --bs-table-accent-bg: transparent !important;
  background-color: transparent !important;
  color: var(--text-color) !important;
}

.table-valign-top td,
.table-valign-top th {
  vertical-align: top;
}

@media (max-width: 899.98px) {
  .table-responsive {
    margin: 0 -1rem;
    padding: 0 1rem;
    width: calc(100% + 2rem);
  }
}

/* Pagination */
.pagination {
  margin-bottom: 0;
}

/* Action buttons */
.btn-sm {
  padding: 0.25rem 0.5rem;
  font-size: var(--text-xs);
}

/* ============================================
   PAGE LOADING BAR
   ============================================ */
/* ============================================
   SPA PAGE TRANSITIONS
   ============================================ */

/* SPA page transitions - snappy crossfade */
.main-content-inner {
  transition: opacity 60ms ease-out;
}

.main-content-inner.spa-transitioning-out {
  opacity: 0;
  transition: opacity 40ms ease-out;
}

.main-content-inner.spa-transitioning-in {
  opacity: 0;
  transition: opacity 80ms ease-out;
}


/* ============================================
   MOBILE RADIAL MENU
   ============================================ */

/* Trigger button - bottom right */
.radial-trigger {
  display: none;
  position: fixed;
  bottom: calc(12px + env(safe-area-inset-bottom));
  left: 12px;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: var(--text-color);
  color: var(--bg-color);
  border: none;
  font-size: 1.25rem;
  cursor: pointer;
  z-index: 1001;
  transition: transform 0.2s ease, background-color 0.2s ease;
}

.radial-trigger:hover {
  transform: scale(1.05);
}

.radial-trigger.is-open {
  background: var(--text-muted);
}

.radial-trigger i {
  transition: transform 0.2s ease;
}

.radial-trigger.is-open i {
  transform: rotate(90deg);
}

/* Overlay - subtle dim */
.radial-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: #fff;
  z-index: 999;
  visibility: hidden;
  opacity: 0;
  transition: opacity 0.2s ease, visibility 0.2s ease, background 0.15s ease;
  pointer-events: none;
}

[data-theme="dark"] .radial-overlay {
  background: #000;
}

.radial-overlay.is-open {
  visibility: visible;
  opacity: 1;
  pointer-events: auto;
}

/* Prevent scrolling when radial menu is open - CSS only, no overflow changes */
body.radial-open {
  touch-action: none;
}

body.radial-open .page-wrapper {
  touch-action: none;
  pointer-events: none;
}

/* Theme toggle in radial menu */
.radial-theme-toggle {
  position: absolute;
  bottom: calc(12px + env(safe-area-inset-bottom));
  left: 12px;
  width: 48px;
  height: 48px;
  border: none;
  border-radius: 50%;
  background: var(--text-color);
  color: var(--bg-color);
  font-size: 1.25rem;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
  transition: transform 0.15s ease, background 0.15s ease, color 0.15s ease;
}

.radial-theme-toggle:hover {
  transform: scale(1.1);
}

.radial-theme-toggle:active {
  transform: scale(0.95);
}

.radial-theme-toggle .bi-sun-fill {
  display: none;
}

.radial-theme-toggle .bi-moon-fill {
  display: block;
}

[data-theme="dark"] .radial-theme-toggle {
  background: #fff;
  color: #000;
}

[data-theme="dark"] .radial-theme-toggle .bi-sun-fill {
  display: block;
}

[data-theme="dark"] .radial-theme-toggle .bi-moon-fill {
  display: none;
}

/* Radial menu container - offset lower for thumb reach in portrait */
.radial-menu {
  display: none;
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 1000;
  pointer-events: none;
  visibility: hidden;
  opacity: 0;
  transition: opacity 0.2s ease, visibility 0.2s ease;
}

.radial-menu.is-open {
  visibility: visible;
  pointer-events: auto;
  opacity: 1;
}

/* Loading state after selection */
.radial-menu.is-loading .radial-donut {
  animation: radialPulse 0.4s ease infinite;
}

.radial-item.is-navigating {
  transform: scale(1.2);
  color: var(--highlight);
}

.radial-item.is-navigating i {
  animation: radialSpin 0.5s linear infinite;
}

@keyframes radialPulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.6; }
}

@keyframes radialSpin {
  to { transform: rotate(360deg); }
}

/* The donut container - sized to fill screen with padding */
.radial-donut {
  --donut-size: min(87vw, 87vh, 408px);
  --hole-size: calc(var(--donut-size) * 0.40);
  --ring-width: calc((var(--donut-size) - var(--hole-size)) / 2);
  --ring-center: calc((var(--donut-size) / 2 + var(--donut-size) * 0.25) / 2);
  --segment-color: rgba(0, 0, 0, 0.15);
  position: relative;
  width: var(--donut-size);
  height: var(--donut-size);
  border-radius: 50%;
  background: #f0f0f0;
  overflow: hidden;
  transition: background 0.15s ease;
  /* Transparent hole in center */
  -webkit-mask: radial-gradient(circle at center, transparent calc(var(--hole-size) / 2 - 1px), black calc(var(--hole-size) / 2));
  mask: radial-gradient(circle at center, transparent calc(var(--hole-size) / 2 - 1px), black calc(var(--hole-size) / 2));
}

/* Pie segments - masked to ring only */
.radial-segment {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  transition: opacity 0.15s ease;
  /* Mask to only show in the ring area */
  -webkit-mask: radial-gradient(circle at center, transparent calc(var(--hole-size) / 2 - 1px), black calc(var(--hole-size) / 2));
  mask: radial-gradient(circle at center, transparent calc(var(--hole-size) / 2 - 1px), black calc(var(--hole-size) / 2));
}

/* Segment highlights - 6 segments, 60° each */
.radial-segment[data-segment="0"] {
  background: conic-gradient(from -30deg at 50% 50%, var(--segment-color) 0deg 60deg, transparent 60deg);
}
.radial-segment[data-segment="1"] {
  background: conic-gradient(from 30deg at 50% 50%, var(--segment-color) 0deg 60deg, transparent 60deg);
}
.radial-segment[data-segment="2"] {
  background: conic-gradient(from 90deg at 50% 50%, var(--segment-color) 0deg 60deg, transparent 60deg);
}
.radial-segment[data-segment="3"] {
  background: conic-gradient(from 150deg at 50% 50%, var(--segment-color) 0deg 60deg, transparent 60deg);
}
.radial-segment[data-segment="4"] {
  background: conic-gradient(from 210deg at 50% 50%, var(--segment-color) 0deg 60deg, transparent 60deg);
}
.radial-segment[data-segment="5"] {
  background: conic-gradient(from 257deg at 50% 50%, var(--segment-color) 0deg 51deg, transparent 51deg);
}
.radial-segment[data-segment="6"] {
  background: conic-gradient(from 308deg at 50% 50%, var(--segment-color) 0deg 51deg, transparent 51deg);
}

.radial-segment.is-selected {
  opacity: 1;
}


/* Menu items positioned in a circle */
.radial-item {
  --icon-size: 56px;
  position: absolute;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2px;
  text-decoration: none;
  color: var(--text-muted);
  width: var(--icon-size);
  height: var(--icon-size);
  text-align: center;
  opacity: 0;
  transform: scale(0.6);
  transition: opacity 0.2s ease, transform 0.2s ease, color 0.15s ease;
  z-index: 3;
  top: 50%;
  left: 50%;
}

.radial-menu.is-open .radial-item {
  opacity: 1;
  transform: scale(1);
}

/* Stagger animation */
.radial-menu.is-open .radial-item[data-angle="0"] { transition-delay: 0ms; }
.radial-menu.is-open .radial-item[data-angle="1"] { transition-delay: 20ms; }
.radial-menu.is-open .radial-item[data-angle="2"] { transition-delay: 40ms; }
.radial-menu.is-open .radial-item[data-angle="3"] { transition-delay: 60ms; }
.radial-menu.is-open .radial-item[data-angle="4"] { transition-delay: 80ms; }
.radial-menu.is-open .radial-item[data-angle="5"] { transition-delay: 100ms; }
.radial-menu.is-open .radial-item[data-angle="6"] { transition-delay: 120ms; }

/* Position 6 items centered in the ring */
/* Angles: 0°, 60°, 120°, 180°, 240°, 300° */
.radial-item[data-angle="0"] {
  /* 0°: sin=0, cos=1 */
  margin-top: calc(-1 * var(--ring-center) - var(--icon-size) / 2);
  margin-left: calc(-1 * var(--icon-size) / 2);
}
.radial-item[data-angle="1"] {
  /* 60°: sin=0.866, cos=0.5 */
  margin-top: calc(-0.5 * var(--ring-center) - var(--icon-size) / 2);
  margin-left: calc(0.866 * var(--ring-center) - var(--icon-size) / 2);
}
.radial-item[data-angle="2"] {
  /* 120°: sin=0.866, cos=-0.5 */
  margin-top: calc(0.5 * var(--ring-center) - var(--icon-size) / 2);
  margin-left: calc(0.866 * var(--ring-center) - var(--icon-size) / 2);
}
.radial-item[data-angle="3"] {
  /* 180°: sin=0, cos=-1 */
  margin-top: calc(1 * var(--ring-center) - var(--icon-size) / 2);
  margin-left: calc(-1 * var(--icon-size) / 2);
}
.radial-item[data-angle="4"] {
  /* 240°: sin=-0.866, cos=-0.5 */
  margin-top: calc(0.5 * var(--ring-center) - var(--icon-size) / 2);
  margin-left: calc(-0.866 * var(--ring-center) - var(--icon-size) / 2);
}
.radial-item[data-angle="5"] {
  /* 300°: sin=-0.866, cos=0.5 */
  margin-top: calc(-0.5 * var(--ring-center) - var(--icon-size) / 2);
  margin-left: calc(-0.866 * var(--ring-center) - var(--icon-size) / 2);
}
.radial-item[data-angle="6"] {
  /* 330°: sin=-0.5, cos=0.866 */
  margin-top: calc(-0.866 * var(--ring-center) - var(--icon-size) / 2);
  margin-left: calc(-0.5 * var(--ring-center) - var(--icon-size) / 2);
}

.radial-item:hover,
.radial-item:focus {
  color: var(--text-color);
}

.radial-item[data-active] {
  color: var(--text-color);
}

/* Rotary dial selection state - scale up the icon */
.radial-item.is-selected {
  color: var(--highlight);
}

.radial-item.is-selected i {
  transform: scale(1.3);
}

.radial-item i {
  font-size: clamp(1.25rem, 4vw, 1.5rem);
  transition: transform 0.15s ease;
}

.radial-label {
  font-size: 9px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  white-space: nowrap;
  opacity: 0.8;
}

@media (max-width: 899.98px) {
  .radial-trigger,
  .radial-overlay,
  .radial-menu {
    display: block;
  }

  /* Hide sidebar on mobile */
  .sidebar {
    display: none !important;
  }

  /* Adjust main content */
  main.main-content {
    left: 10px !important;
  }
  .main-content-inner {
    padding-bottom: 2rem;
  }

  /* Hide top bar title on mobile */
  .top-bar-title {
    display: none;
  }

  .top-bar {
    top: 12px;
    left: auto;
    right: 12px;
    height: auto;
    padding: 0;
    background: transparent;
  }

  .top-bar-icon {
    margin-right: 0.375rem;
  }

  /* Position floating UI centered at bottom on mobile, between burger and add buttons */
  .floating-ui {
    position: fixed;
    bottom: calc(12px + env(safe-area-inset-bottom));
    left: 50%;
    transform: translateX(-50%);
    z-index: 1001;
  }

  .floating-pill {
    height: 48px;
    padding: 0;
    border-radius: 24px;
    gap: 0;
    border: none;
    background: transparent;
  }

  .floating-btn {
    width: 48px;
    height: 48px;
    min-width: 48px;
    padding: 0;
    border-radius: 50%;
    background: var(--bg-color);
    border: 1px solid var(--border-color);
  }

  .floating-btn.active {
    background: var(--text-color);
    color: var(--bg-color);
    border-color: var(--text-color);
  }

  .floating-btn i {
    font-size: 1.25rem;
  }

  /* Hide orbital view button on mobile - not optimized for touch */
  #orbitalViewBtn {
    display: none;
  }

  /* FAB on right side */
  .floating-action-btn {
    bottom: calc(12px + env(safe-area-inset-bottom));
    right: 12px;
    left: auto;
    transform: none;
  }
}

/* Landscape mobile - use compact sidebar instead of wheel */
@media (max-width: 899.98px) and (orientation: landscape) {
  /* Hide radial menu in landscape */
  .radial-trigger,
  .radial-overlay,
  .radial-menu {
    display: none !important;
  }

  /* Show compact sidebar */
  .sidebar {
    display: block !important;
    width: 56px;
  }

  .sidebar-sticky {
    height: 100vh;
    padding-bottom: 0;
    display: flex;
    flex-direction: column;
    justify-content: center;
  }

  /* Compact nav items to fit in viewport */
  .sidebar .nav-link {
    width: 36px;
    height: 36px;
    margin: 0.15rem auto;
  }

  .sidebar .nav-link i {
    font-size: 1rem;
  }

  /* Smaller brand */
  .sidebar-brand {
    padding: 0.5rem 0;
  }

  /* Compact divider */
  .sidebar .sidebar-divider {
    margin: 0.25rem 0.75rem;
  }

  /* Hide settings section to save space */
  .sidebar-settings {
    display: none;
  }

  /* Adjust main content */
  main.main-content {
    left: calc(10px + 56px + var(--spacing-xl)) !important;
  }

  /* Hide mobile logo in landscape (sidebar visible) */
  .top-bar-logo {
    display: none !important;
  }
}

[data-theme="dark"] .radial-donut {
  background: #1a1a1a;
  --segment-color: rgba(255, 255, 255, 0.12);
}

[data-theme="dark"] .radial-trigger {
  background: #fff;
  color: #000;
}

[data-theme="dark"] .radial-trigger.is-open {
  background: #666;
  color: #fff;
}

/* Top bar logo (mobile only) - fixed position like profile */
.top-bar-logo {
  display: none;
  position: fixed;
  top: 12px;
  left: 12px;
  z-index: 101;
  text-decoration: none;
}

.top-bar-logo-circle {
  width: 36px;
  height: 36px;
  background: var(--text-color);
  color: var(--bg-color);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  font-weight: 700;
  transition: transform 0.15s ease;
}

.top-bar-logo:hover .top-bar-logo-circle {
  transform: scale(1.05);
}

/* Mobile sidebar tray - app-like drawer */
.mobile-sidebar-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.3);
  z-index: 998;
  opacity: 0;
  transition: opacity 0.3s ease;
  pointer-events: none;
}

.mobile-sidebar-overlay.is-open {
  display: block;
  opacity: 1;
  pointer-events: auto;
}

.mobile-sidebar {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  bottom: 0;
  width: 80vw;
  max-width: 320px;
  background: var(--bg-color);
  border-right: 1px solid var(--border-color);
  z-index: 999;
  padding: 72px 12px 24px;
  -webkit-transform: translateX(-100%);
  transform: translateX(-100%);
  flex-direction: column;
  align-items: stretch;
  gap: 0.25rem;
  overflow-y: auto;
}

.mobile-sidebar.is-ready {
  -webkit-transition: -webkit-transform 0.3s ease-out !important;
  transition: transform 0.3s ease-out !important;
}

.mobile-sidebar.is-open {
  -webkit-transform: translateX(0);
  transform: translateX(0);
}

.mobile-sidebar-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 16px;
  border-radius: 12px;
  color: var(--text-muted);
  text-decoration: none;
  transition: background 0.15s ease, color 0.15s ease;
  font-size: var(--text-sm);
  font-weight: 500;
}

.mobile-sidebar-item:hover {
  background: var(--hover-bg);
  color: var(--text-color);
}

.mobile-sidebar-item.active {
  background: var(--text-color);
  color: var(--bg-color);
}

.mobile-sidebar-item i {
  font-size: 1.25rem;
  width: 24px;
  text-align: center;
}

/* Page wrapper for mobile drawer effect */
.page-wrapper {
  min-height: 100vh;
  -webkit-transition: -webkit-transform 0.3s ease-out, opacity 0.3s ease-out !important;
  transition: transform 0.3s ease-out, opacity 0.3s ease-out !important;
}

/* Inner flex container for main + right sidebar */
.page-wrapper > .d-flex {
  min-height: 100vh;
  align-items: flex-start;
}

/* Mobile-only: overlay behavior for left sidebar */
@media (max-width: 899.98px) {
  body.sidebar-open .page-wrapper {
    opacity: 0.5;
    overflow: hidden;
    touch-action: none;
    cursor: pointer;
  }

  body.sidebar-open .page-wrapper * {
    pointer-events: none;
  }

  /* Lock scrolling when sidebar is open */
  html.sidebar-open,
  body.sidebar-open {
    overflow: hidden;
    touch-action: none;
  }
}

/* Mobile add button (bottom right) */
.mobile-add-wrapper {
  display: none;
  position: fixed;
  bottom: calc(12px + env(safe-area-inset-bottom));
  right: 12px;
  z-index: 1001;
}

.mobile-add-btn {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: var(--text-color);
  color: var(--bg-color);
  border: none;
  font-size: 1.25rem;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform 0.2s ease, background-color 0.2s ease;
}

.mobile-add-btn:active {
  transform: scale(0.95);
}

.mobile-add-btn i {
  transition: transform 0.2s ease;
}

.mobile-add-btn.is-open i {
  transform: rotate(45deg);
}

.mobile-add-menu {
  position: fixed;
  bottom: calc(72px + env(safe-area-inset-bottom));
  left: 5px;
  right: 5px;
  background: var(--bg-color);
  border-radius: 16px;
  box-shadow: 0 4px 24px rgba(0, 0, 0, 0.2);
  padding: 12px;
  opacity: 0;
  visibility: hidden;
  transform: translateY(16px);
  transition: all 0.25s ease-out;
}

.mobile-add-menu.is-open {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.mobile-add-menu-item {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 16px 20px;
  color: var(--text-color);
  text-decoration: none;
  border-radius: 12px;
  font-size: 1.125rem;
  font-weight: 500;
  transition: background 0.15s ease;
}

.mobile-add-menu-item:hover,
.mobile-add-menu-item:active {
  background: var(--hover-bg);
  color: var(--text-color);
}

.mobile-add-menu-item i {
  font-size: 1.5rem;
  color: var(--text-muted);
  width: 32px;
}

@media (max-width: 899.98px) {
  .mobile-add-wrapper {
    display: block;
  }

  /* Hide page-level FABs on mobile (use mobile-add-btn instead) */
  .floating-action-btn {
    display: none !important;
  }
}

/* Dark mode */
[data-theme="dark"] .mobile-add-btn {
  background: #fff;
  color: #000;
}

[data-theme="dark"] .mobile-add-menu {
  background: #1a1a1a;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.4);
}

/* Test mobile mode */
body.test-mobile .mobile-add-wrapper {
  display: block;
}

body.test-mobile .floating-action-btn {
  display: none !important;
}

@media (max-width: 899.98px) {
  .mobile-sidebar {
    display: flex;
    flex-direction: column;
  }

  .top-bar-logo {
    border: none;
    background: none;
    padding: 0;
    cursor: pointer;
  }

  /* FAB on right side */
  .floating-action-btn {
    bottom: calc(12px + env(safe-area-inset-bottom));
    right: 12px;
    left: auto;
    transform: none;
  }
}

[data-theme="dark"] .mobile-sidebar {
  background: var(--bg-color);
}

[data-theme="dark"] .mobile-sidebar-overlay {
  background: rgba(0, 0, 0, 0.6);
}

/* ============================================
   BOTTOM TAB BAR
   Floating pill navigation for mobile
   ============================================ */

.bottom-tab-bar {
  display: none;
  position: fixed;
  bottom: 12px;
  left: 12px;
  right: 12px;
  height: 56px;
  background: var(--bg-color);
  border-radius: 16px;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.15);
  z-index: 1000;
  padding: 0 8px;
  align-items: center;
  justify-content: space-between;
  gap: 4px;
  /* iOS safe area */
  padding-bottom: max(0px, calc(env(safe-area-inset-bottom) - 12px));
}

@supports (padding-bottom: env(safe-area-inset-bottom)) {
  .bottom-tab-bar {
    bottom: calc(12px + env(safe-area-inset-bottom));
  }
}

.bottom-tab-nav {
  display: flex;
  align-items: center;
  gap: 4px;
  flex: 1;
}

.bottom-tab-item {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border-radius: 12px;
  color: var(--text-muted);
  text-decoration: none;
  transition: all 0.15s ease;
}

.bottom-tab-item:hover {
  background: var(--hover-bg);
  color: var(--text-color);
}

.bottom-tab-item.active {
  background: var(--text-color);
  color: var(--bg-color);
}

.bottom-tab-item i {
  font-size: 1.25rem;
}

/* Add button */
.bottom-tab-add {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border-radius: 12px;
  background: var(--highlight);
  color: #fff;
  border: none;
  cursor: pointer;
  transition: all 0.15s ease;
  position: relative;
}

.bottom-tab-add:hover {
  opacity: 0.9;
}

.bottom-tab-add:active {
  transform: scale(0.95);
}

.bottom-tab-add i {
  font-size: 1.25rem;
  transition: transform 0.2s ease;
}

.bottom-tab-add.is-open i {
  transform: rotate(45deg);
}

/* Add menu popup */
.bottom-tab-add-menu {
  position: absolute;
  bottom: calc(100% + 8px);
  right: 0;
  background: var(--bg-color);
  border-radius: 12px;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.15);
  padding: 8px;
  min-width: 160px;
  opacity: 0;
  visibility: hidden;
  transform: translateY(8px);
  transition: all 0.2s ease;
}

.bottom-tab-add-menu.is-open {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.bottom-tab-add-menu a {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px;
  color: var(--text-color);
  text-decoration: none;
  border-radius: 8px;
  font-size: var(--text-sm);
  transition: background 0.15s ease;
}

.bottom-tab-add-menu a:hover {
  background: var(--hover-bg);
}

.bottom-tab-add-menu a i {
  font-size: 1rem;
  color: var(--text-muted);
}

/* Show on mobile */
@media (max-width: 899.98px) {
  .bottom-tab-bar {
    display: flex;
  }
}

/* Dark mode */
[data-theme="dark"] .bottom-tab-bar {
  background: #1a1a1a;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.4);
}

[data-theme="dark"] .bottom-tab-add-menu {
  background: #1a1a1a;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.4);
}

/* Test mobile mode */
body.test-mobile .bottom-tab-bar {
  display: flex;
}

@media (max-width: 899.98px) {
  .top-bar-logo {
    display: block;
  }
}

[data-theme="dark"] .top-bar-logo-circle {
  background: #fff;
  color: #000;
}

/* Force mobile styles for testing on localhost */
body.test-mobile .radial-trigger,
body.test-mobile .radial-overlay,
body.test-mobile .radial-menu {
  display: block;
}

body.test-mobile .mobile-sidebar {
  display: flex;
  flex-direction: column;
}


body.test-mobile .sidebar {
  display: none !important;
}

body.test-mobile main.main-content {
  left: 10px !important;
}
body.test-mobile .main-content-inner {
  padding-bottom: 2rem;
}

body.test-mobile .top-bar-title {
  display: none;
}

body.test-mobile .top-bar-logo {
  display: block;
}

/* Position floating UI centered at bottom on mobile */
body.test-mobile .floating-ui {
  position: fixed;
  bottom: calc(12px + env(safe-area-inset-bottom));
  left: 50%;
  transform: translateX(-50%);
  z-index: 1001;
}

/* FAB on right side */
body.test-mobile .floating-action-btn {
  bottom: 12px;
  right: 12px;
  left: auto;
  transform: none;
  height: 48px;
  min-width: 48px;
  border-radius: 24px;
}

/* Radial trigger */
body.test-mobile .radial-trigger {
  bottom: 12px;
  left: 12px;
  right: auto;
}

/* Status dot (legacy) */
.status-dot {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  vertical-align: middle;
}

.status-dot.status-active {
  background-color: #22c55e;
}

.status-dot.status-inactive {
  background-color: #6b7280;
}

/* Publish toggle switch */
.publish-toggle {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
}

.publish-toggle .form-check-input,
.publish-toggle-inline .form-check-input {
  width: 2.75rem;
  height: 1.5rem;
  margin: 0;
  cursor: pointer;
  background-color: #6b7280;
  border: none;
  border-radius: 1rem;
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3e%3ccircle r='3' fill='white'/%3e%3c/svg%3e");
  background-position: left center;
  background-size: contain;
  transition: background-color 0.15s ease-in-out, background-position 0.15s ease-in-out;
}

.publish-toggle .form-check-input:checked,
.publish-toggle-inline .form-check-input:checked {
  background-color: #22c55e;
  background-position: right center;
}

.publish-toggle .form-check-input:focus,
.publish-toggle-inline .form-check-input:focus {
  box-shadow: none;
}

.publish-toggle-label {
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--text-muted);
}

.publish-toggle .form-check-input:checked + .publish-toggle-label {
  color: #22c55e;
}

/* Inline publish toggle for tables/lists */
.publish-toggle-inline {
  display: inline-flex;
  align-items: center;
}

.publish-toggle-inline .form-check-input {
  width: 2.25rem;
  height: 1.25rem;
}

/* Badges */
.badge {
  font-size: var(--text-xs);
  font-weight: 500;
  letter-spacing: 0.02em;
}

/* ============================================
   LOGIN PAGE
   ============================================ */

.login-page {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-height: 100vh;
  min-height: 100dvh;
  padding: 2rem;
  background-color: #0a0a0a;
  color: #fafafa;
}

/* Form container */
.login-form {
  width: 100%;
  max-width: 320px;
}

/* Title */
.login-title {
  font-size: 1.75rem;
  font-weight: 500;
  letter-spacing: -0.025em;
  text-align: center;
  margin: 0 0 2.5rem;
  color: #fafafa;
}

/* Error message */
.login-error {
  padding: 0.875rem 1rem;
  margin-bottom: 1.5rem;
  font-size: 0.875rem;
  line-height: 1.4;
  color: #fca5a5;
  background: rgba(220, 38, 38, 0.15);
  border-radius: 8px;
}

/* Fields container */
.login-fields {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

/* Input field wrapper */
.login-field {
  position: relative;
  border-radius: 10px;
}

/* Gradient border wrapper */
.login-field::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: 10px;
  padding: 1.5px;
  background: conic-gradient(
    from 0deg,
    #3b82f6,
    #8b5cf6,
    #ec4899,
    #f43f5e,
    #8b5cf6,
    #3b82f6
  );
  -webkit-mask:
    linear-gradient(#fff 0 0) content-box,
    linear-gradient(#fff 0 0);
  mask:
    linear-gradient(#fff 0 0) content-box,
    linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  opacity: 0;
  transition: opacity 300ms cubic-bezier(0.4, 0, 0.2, 1);
  pointer-events: none;
}

.login-field:focus-within::before {
  opacity: 1;
}

.login-field input {
  position: relative;
  width: 100%;
  height: 56px;
  padding: 1.25rem 1rem 0.5rem;
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.5;
  color: #fafafa;
  background: #0a0a0a;
  border: 1.5px solid rgba(255, 255, 255, 0.15);
  border-radius: 10px;
  outline: none;
  transition:
    border-color 200ms cubic-bezier(0.4, 0, 0.2, 1),
    background-color 200ms cubic-bezier(0.4, 0, 0.2, 1);
  -webkit-appearance: none;
  appearance: none;
}

.login-field input::placeholder {
  color: transparent;
}

.login-field input:hover {
  border-color: rgba(255, 255, 255, 0.25);
}

.login-field input:focus {
  border-color: transparent;
  background: rgba(255, 255, 255, 0.03);
}

/* Floating label */
.login-field label {
  position: absolute;
  left: 1rem;
  top: 50%;
  transform: translateY(-50%) scale(1);
  font-size: 1rem;
  font-weight: 400;
  color: rgba(255, 255, 255, 0.5);
  pointer-events: none;
  transform-origin: left center;
  transition: all 200ms cubic-bezier(0.4, 0, 0.2, 1);
}

/* Label shrinks and fades when focused or has value */
.login-field input:focus + label,
.login-field input:not(:placeholder-shown) + label {
  top: 0.625rem;
  transform: translateY(0) scale(0.75);
  opacity: 0.4;
}

/* Remember me checkbox */
.login-remember {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-top: 0.5rem;
  cursor: pointer;
  -webkit-user-select: none;
  user-select: none;
}

.login-remember input {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
}

.login-checkbox {
  position: relative;
  width: 20px;
  height: 20px;
  flex-shrink: 0;
  border: 1.5px solid rgba(255, 255, 255, 0.2);
  border-radius: 5px;
  transition: all 200ms cubic-bezier(0.4, 0, 0.2, 1);
}

.login-remember:hover .login-checkbox {
  border-color: rgba(255, 255, 255, 0.35);
}

.login-remember input:focus-visible + .login-checkbox {
  border-color: rgba(255, 255, 255, 0.5);
  box-shadow: 0 0 0 3px rgba(255, 255, 255, 0.05);
}

.login-remember input:checked + .login-checkbox {
  background: #fafafa;
  border-color: #fafafa;
}

.login-checkbox::after {
  content: '';
  position: absolute;
  top: 3px;
  left: 6px;
  width: 5px;
  height: 9px;
  border: solid #0a0a0a;
  border-width: 0 2px 2px 0;
  transform: rotate(45deg) scale(0);
  transition: transform 200ms cubic-bezier(0.4, 0, 0.2, 1);
}

.login-remember input:checked + .login-checkbox::after {
  transform: rotate(45deg) scale(1);
}

.login-remember-text {
  font-size: 0.875rem;
  color: rgba(255, 255, 255, 0.5);
  transition: color 200ms cubic-bezier(0.4, 0, 0.2, 1);
}

.login-remember:hover .login-remember-text {
  color: rgba(255, 255, 255, 0.8);
}

/* Submit button */
.login-submit {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 52px;
  margin-top: 1rem;
  padding: 0 1.5rem;
  font-size: 1rem;
  font-weight: 500;
  color: #0a0a0a;
  background: #fafafa;
  border: none;
  border-radius: 10px;
  cursor: pointer;
  transition: all 200ms cubic-bezier(0.4, 0, 0.2, 1);
  -webkit-appearance: none;
  appearance: none;
}

.login-submit:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.4);
}

.login-submit:active {
  transform: translateY(0) scale(0.98);
  box-shadow: none;
}

.login-submit:focus-visible {
  outline: 2px solid rgba(255, 255, 255, 0.5);
  outline-offset: 2px;
}

.login-submit-text {
  transition: opacity 200ms cubic-bezier(0.4, 0, 0.2, 1);
}

/* Sign up link */
.login-signup {
  margin-top: 2rem;
  font-size: 0.875rem;
  color: rgba(255, 255, 255, 0.5);
  text-align: center;
}

.login-signup a {
  color: #fafafa;
  text-decoration: none;
  font-weight: 500;
  transition: opacity 200ms cubic-bezier(0.4, 0, 0.2, 1);
}

.login-signup a:hover {
  opacity: 0.7;
}

/* Footer */
.login-footer {
  position: absolute;
  bottom: 2rem;
  left: 0;
  right: 0;
  font-size: 0.75rem;
  color: rgba(255, 255, 255, 0.3);
  text-align: center;
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
  .login-field input,
  .login-field label,
  .login-field::before,
  .login-checkbox,
  .login-checkbox::after,
  .login-submit,
  .login-remember-text,
  .login-signup a {
    transition: none;
  }
}

/* ============================================
   SIDEBAR MINI PLAYER
   ============================================ */

.sidebar-mini-player {
  display: none;
  position: absolute;
  bottom: calc(3rem + 44px + 1rem + 0.5rem + 44px + var(--spacing-lg));
  left: 0;
  right: 0;
  padding: 0;
  justify-content: center;
}

.sidebar-mini-player-btn {
  position: relative;
  width: 52px;
  height: 52px;
  aspect-ratio: 1 / 1;
  border-radius: 50%;
  background: var(--bg-secondary);
  background-size: cover;
  background-position: center;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: opacity 0.15s ease;
  overflow: hidden;
  box-shadow: 0 2px 8px rgba(0,0,0,0.15);
  padding: 0;
  flex-shrink: 0;
}

.sidebar-mini-player-btn:hover {
  opacity: 0.85;
}

.sidebar-mini-player-btn.has-artwork .sidebar-mini-player-icon {
  color: white;
  text-shadow: 0 1px 3px rgba(0,0,0,0.5);
}

.sidebar-mini-player-ring {
  position: absolute;
  top: 0;
  left: 0;
  width: 52px;
  height: 52px;
  transform: rotate(-90deg);
  pointer-events: none;
}

.sidebar-mini-player-ring-bg {
  stroke: var(--border-color);
}

.sidebar-mini-player-ring-fill {
  stroke: var(--highlight);
  transition: stroke-dashoffset 0.1s linear;
}

.sidebar-mini-player-icon {
  font-size: 1.25rem;
  color: var(--text-color);
  z-index: 1;
}

/* Show mini player when right sidebar is hidden (mobile) */
@media (max-width: 899.98px) {
  .sidebar-mini-player {
    display: flex;
    bottom: calc(3rem + 44px + 0.5rem + 44px + var(--spacing-lg));
  }
}

/* ============================================
   SIDEBAR ORGANISATION PROFILE
   Mirrors .sidebar-settings / .btn-settings pattern exactly
   ============================================ */

.sidebar-bottom-row {
  margin-top: auto;
  padding: 0.75rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--spacing-xs);
}

.sidebar-org {
  padding: 0;
  display: flex;
  justify-content: center;
}

.sidebar-org-link {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  padding: 0;
  border-radius: 50%;
  border: 2px solid var(--border-color);
  background: var(--bg-secondary);
  color: var(--text-muted);
  text-decoration: none;
  transition: transform 0.15s ease, box-shadow 0.15s ease, border-color 0.15s ease;
  overflow: hidden;
}

.sidebar-org-link:hover {
  transform: scale(1.05);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
}

.sidebar-org-link:active {
  transform: scale(0.95);
}

.sidebar-org-link i {
  font-size: 1.25rem;
}

.sidebar-org-logo {
  width: 100%;
  height: 100%;
  border-radius: 50%;
  object-fit: cover;
}

.sidebar-org-name {
  display: none;
}

/* ============================================
   SETTINGS BUTTON & PANEL
   ============================================ */

.sidebar-settings {
  padding: 0;
  display: flex;
  justify-content: center;
}

.btn-settings {
  position: relative;
  width: 44px;
  height: 44px;
  padding: 0;
  margin: 0;
  border-radius: var(--radius-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  background: none;
  border: none;
  color: var(--text-color);
  font-weight: 500;
  cursor: pointer;
  transition:
    color var(--duration-fast) var(--ease-out),
    background-color var(--duration-fast) var(--ease-out),
    transform var(--duration-instant) var(--ease-out);
}

.btn-settings:hover {
  background-color: var(--bg-secondary);
}

.btn-settings:active {
  transform: scale(0.95);
}

.btn-settings.active {
  color: #007bff;
}

.btn-settings i {
  font-size: 1.25rem;
  width: 24px;
  flex-shrink: 0;
  text-align: center;
}

.btn-settings .nav-text {
  display: none;
}

/* Settings Panel */
.settings-panel {
  position: fixed;
  top: var(--panel-inset);
  left: calc(var(--panel-inset) + var(--sidebar-collapsed) + var(--panel-gap));
  width: 260px;
  max-height: calc(100vh - 2rem);
  background: var(--bg-color);
  border-radius: 16px;
  box-shadow: 0 4px 24px rgba(0, 0, 0, 0.12);
  z-index: 1040;
  padding: 1rem;
  transform: translateX(-12px);
  opacity: 0;
  visibility: hidden;
  transition:
    transform var(--duration-normal) var(--ease-out),
    opacity var(--duration-fast) var(--ease-out),
    visibility var(--duration-normal);
  overflow-y: auto;
}

/* Collapsed sidebar - move settings panel with sidebar */
@media (max-width: 1600px) {
  .settings-panel {
    left: calc(var(--panel-inset) + var(--sidebar-collapsed) + var(--panel-inset));
  }
}

.settings-panel.open {
  transform: translateX(0);
  opacity: 1;
  visibility: visible;
}

.settings-panel-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-bottom: 0.75rem;
  margin-bottom: 0.5rem;
  border-bottom: 1px solid var(--border-color);
}

.settings-panel-header h6 {
  font-size: var(--text-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--text-muted);
}

.btn-close-panel {
  background: none;
  border: none;
  color: var(--text-muted);
  cursor: pointer;
  padding: 0.25rem;
  line-height: 1;
  transition: color 0.2s ease;
}

.btn-close-panel:hover {
  color: var(--text-color);
}

.settings-panel .nav-link {
  display: flex;
  align-items: center;
  padding: var(--spacing-md) var(--spacing-md);
  color: var(--text-color);
  font-weight: 500;
  font-size: var(--text-sm);
  border-radius: 8px;
  transition:
    background-color var(--duration-fast) var(--ease-out),
    color var(--duration-fast) var(--ease-out);
}

.settings-panel .nav-link:hover {
  background-color: rgba(0, 123, 255, 0.08);
  color: #007bff;
}

.settings-panel .nav-link.active {
  background-color: rgba(0, 123, 255, 0.1);
  color: #007bff;
}

.settings-panel .nav-link i {
  font-size: 1rem;
  width: 24px;
  text-align: center;
  margin-right: 0.5rem;
}

.settings-panel-backdrop {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 1030;
  visibility: hidden;
  opacity: 0;
  transition:
    opacity var(--duration-normal) var(--ease-out),
    visibility var(--duration-normal);
}

.settings-panel-backdrop.open {
  visibility: visible;
  opacity: 1;
}

/* ============================================
   ARTIST SWITCHER
   ============================================ */

.artist-switcher-trigger {
  width: 48px;
  height: 48px;
  min-width: 48px;
  min-height: 48px;
  border-radius: 50%;
  border: 2px solid var(--border-color);
  background: var(--bg-secondary);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform 0.15s ease, box-shadow 0.15s ease, border-color 0.15s ease;
  flex-shrink: 0;
  overflow: hidden;
  padding: 0;
}

.artist-switcher-trigger:hover {
  transform: scale(1.05);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
}

.artist-switcher-trigger.is-open {
  transform: scale(1.1);
  box-shadow: 0 0 0 2px var(--highlight);
}

.artist-switcher-trigger img {
  width: 100%;
  height: 100%;
  border-radius: 50%;
  object-fit: cover;
}

.artist-switcher-trigger-placeholder {
  color: var(--text-muted);
  font-size: 1.25rem;
}

.artist-switcher-tray {
  position: fixed;
  top: calc(10px + 1rem);
  left: 50%;
  transform: translateX(-50%) translateY(-100%);
  max-width: calc(100vw - 20px);
  background: var(--bg-color);
  border-radius: 9999px;
  z-index: 1050;
  padding: 0.5rem 0.75rem;
  /* Extra padding for org and add buttons */
  padding-left: calc(48px + 1.5rem + 0.75rem);
  padding-right: calc(48px + 1.5rem + 0.75rem);
  opacity: 0;
  visibility: hidden;
  transition:
    transform var(--duration-normal) var(--ease-out),
    opacity var(--duration-fast) var(--ease-out),
    visibility var(--duration-normal);
  box-shadow: 0 4px 24px rgba(0, 0, 0, 0.12);
  display: flex;
  align-items: center;
  justify-content: center;
}

.artist-switcher-tray.is-open {
  transform: translateX(-50%) translateY(0);
  opacity: 1;
  visibility: visible;
}

/* Organisation button - absolutely positioned left */
.artist-switcher-org {
  position: absolute;
  left: 0.75rem;
  top: 50%;
  transform: translateY(-50%);
  width: 48px;
  height: 48px;
  border-radius: 8px;
  border: 2px solid transparent;
  background: var(--bg-secondary);
  cursor: pointer;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform 0.15s ease, border-color 0.15s ease;
  padding: 0;
}

.artist-switcher-org:hover {
  transform: translateY(-50%) scale(1.08);
}

.artist-switcher-org.is-selected {
  border-color: var(--highlight);
  transform: translateY(-50%) scale(1.08);
}

.artist-switcher-org img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 6px;
}

.artist-switcher-org-placeholder {
  color: var(--text-muted);
  font-size: 1.25rem;
}

/* Divider between org and artists */
.artist-switcher-org::after {
  content: '';
  position: absolute;
  right: -0.75rem;
  top: 50%;
  transform: translateY(-50%);
  width: 1px;
  height: 32px;
  background: var(--border-color);
}

.artist-switcher-list {
  display: flex;
  flex-wrap: nowrap;
  justify-content: center;
  gap: 0.5rem;
}

/* Add button - absolutely positioned right */
.artist-switcher-add-fixed {
  position: absolute;
  right: 0.75rem;
  top: 50%;
  transform: translateY(-50%);
}

.artist-switcher-add-fixed::before {
  content: '';
  position: absolute;
  left: -0.75rem;
  top: 50%;
  transform: translateY(-50%);
  width: 1px;
  height: 32px;
  background: var(--border-color);
}

.artist-switcher-item {
  flex-shrink: 0;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  border: 2px solid transparent;
  background: var(--bg-secondary);
  cursor: pointer;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform 0.15s ease, border-color 0.15s ease;
  padding: 0;
}

.artist-switcher-item:hover {
  transform: scale(1.08);
}

.artist-switcher-item.is-selected {
  border-color: var(--highlight);
  transform: scale(1.08);
}

.artist-switcher-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 50%;
}

.artist-switcher-add {
  background: transparent;
  border: 2px dashed var(--border-color);
  color: var(--text-muted);
  font-size: 1.25rem;
  text-decoration: none;
}

.artist-switcher-add:hover {
  border-color: var(--text-muted);
  color: var(--text-color);
  background: var(--bg-secondary);
}

/* Override hover for absolutely positioned add button */
.artist-switcher-add-fixed:hover {
  transform: translateY(-50%) scale(1.08);
}

.artist-switcher-placeholder {
  color: var(--text-muted);
  font-size: 1.5rem;
}

.artist-switcher-backdrop {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 1040;
  background: rgba(0, 0, 0, 0.3);
  visibility: hidden;
  opacity: 0;
  transition:
    opacity var(--duration-normal) var(--ease-out),
    visibility var(--duration-normal);
}

.artist-switcher-backdrop.is-open {
  visibility: visible;
  opacity: 1;
}

[data-theme="dark"] .artist-switcher-tray {
  box-shadow: 0 4px 24px rgba(0, 0, 0, 0.4);
}

[data-theme="dark"] .artist-switcher-backdrop {
  background: rgba(0, 0, 0, 0.6);
}

/* Small screens */
@media (max-width: 899.98px) {
  .sidebar-bottom-row {
    position: static;
    flex-direction: row;
    justify-content: space-between;
    padding: 0.5rem 1rem 1rem;
  }

  .sidebar-settings,
  .sidebar-org {
    padding: 0;
  }

  .sidebar-mini-player {
    position: static;
    padding: 0.5rem 1rem;
  }

  .sidebar-sticky {
    padding-bottom: 1rem;
  }

  .settings-panel {
    left: 1rem;
    right: 1rem;
    width: auto;
    top: auto;
    bottom: 1rem;
    max-height: 60vh;
  }
}

/* ============================================
   EMPTY STATES
   Structured pattern: icon → heading → subtitle → CTA
   ============================================ */

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

.empty-state-icon {
  font-size: 3rem;
  color: var(--text-muted);
  margin-bottom: 1rem;
  display: block;
}

.empty-state-title {
  font-size: var(--text-lg);
  font-weight: 600;
  color: var(--text-color);
  margin-bottom: 0.5rem;
}

.empty-state-subtitle {
  font-size: var(--text-sm);
  color: var(--text-muted);
  margin-bottom: 1.5rem;
}

/* ============================================
   DASHBOARD STAT CARDS
   Minimal, monochrome design
   ============================================ */

.dash-stat-card {
  text-align: center;
  padding: 1.5rem 1rem;
}

.dash-stat-number {
  font-size: var(--text-3xl);
  font-weight: 700;
  color: var(--text-color);
  line-height: 1.2;
  margin-bottom: 0.25rem;
}

.dash-stat-label {
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--text-muted);
  margin-bottom: 0.75rem;
}

/* ============================================
   VIEW TOGGLE (shared artists/loudlinks)
   ============================================ */

.view-toggle .btn.active {
  background-color: #0d6efd;
  border-color: #0d6efd;
  color: #fff;
}

[data-theme="dark"] .view-toggle .btn-outline-secondary {
  border-color: var(--border-color);
  color: var(--text-color);
}

[data-theme="dark"] .view-toggle .btn.active {
  background-color: #0d6efd;
  border-color: #0d6efd;
}

/* ============================================
   VIEW TRANSITIONS
   Smooth fade between list/grid/orbital
   ============================================ */

.view-fade-enter {
  opacity: 0;
}

.view-fade-active {
  opacity: 1;
  transition: opacity 150ms ease;
}

/* ============================================
   FILTER BAR (shared artists/loudlinks)
   ============================================ */

.filter-bar {
  position: fixed;
  top: var(--panel-inset);
  height: 60px;
  /* Center within main content area */
  left: calc((var(--panel-inset) + var(--sidebar-collapsed) + var(--panel-gap)) + ((100vw - var(--panel-inset) - var(--sidebar-collapsed) - var(--panel-gap) - var(--right-sidebar-width) - var(--panel-gap) - var(--panel-inset)) / 2) - 200px);
  z-index: 101;
  display: flex;
  align-items: center;
  gap: 1rem;
  width: 400px;
  padding: 0 1.25rem;
  background: transparent;
  border-radius: 50px;
}

.filter-bar-search {
  flex: 1;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  min-width: 0;
  height: 44px;
  padding: 0 1rem;
  background: var(--bg-color);
  border-radius: 50px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
}

.filter-bar-search i {
  color: var(--text-muted);
  font-size: var(--text-base);
}

.filter-bar-search input {
  flex: 1;
  border: none;
  background: transparent;
  font-size: var(--text-base);
  color: var(--text-color);
  outline: none;
  min-width: 0;
}

.filter-bar-search input::placeholder {
  color: var(--text-muted);
}

.filter-bar-options {
  display: flex;
  gap: 0.5rem;
  flex-shrink: 0;
}

.filter-select {
  height: 44px;
  padding: 0 1rem;
  border: none;
  border-radius: 50px;
  background: var(--bg-color);
  color: var(--text-color);
  font-size: var(--text-sm);
  cursor: pointer;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
}

.filter-select:focus {
  outline: none;
}

/* ============================================
   LIST VIEW (shared artists/loudlinks)
   Clean, minimal row design
   ============================================ */

.list-view {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  padding-bottom: 100px;
}

/* Artists page - multi-column grid layout with pill-shaped rows */
.page-artists .list-view {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.75rem;
}

.page-artists .list-row {
  padding: var(--spacing-md) var(--spacing-lg) var(--spacing-md) var(--spacing-sm);
  min-height: 72px;
  border-radius: 999px;
}

.page-artists .list-row-image {
  width: 56px;
  height: 56px;
  border-radius: 50%;
}

.page-artists .list-row-placeholder {
  border-radius: 50%;
}

.page-artists .list-row-name {
  font-size: 1rem;
}

/* Toggle switch for artists and releases */
.page-artists .list-row-status .form-check-input,
.list-row-status .form-check-input[type="checkbox"],
.list-row-actions .form-check-input[type="checkbox"] {
  width: 40px;
  height: 22px;
  cursor: pointer;
  -webkit-appearance: none;
  appearance: none;
  background-color: var(--border-color);
  background-image: none !important;
  border: none;
  border-radius: 11px;
  position: relative;
  transition: background-color 0.2s ease, transform var(--duration-instant) var(--ease-out);
}

.list-row-status .form-check-input[type="checkbox"]:hover,
.list-row-actions .form-check-input[type="checkbox"]:hover {
  transform: scale(1.05);
}

.list-row-status .form-check-input[type="checkbox"]:active,
.list-row-actions .form-check-input[type="checkbox"]:active {
  transform: scale(0.95);
}

.list-row-status .form-check-input[type="checkbox"]:checked,
.list-row-actions .form-check-input[type="checkbox"]:checked {
  background-color: var(--highlight);
}

.list-row-status .form-check-input[type="checkbox"]::before,
.list-row-actions .form-check-input[type="checkbox"]::before {
  content: '';
  position: absolute;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: white;
  top: 2px;
  left: 2px;
  transition: transform 0.2s cubic-bezier(0.34, 1.56, 0.64, 1), box-shadow 0.15s ease;
  box-shadow: 0 1px 3px rgba(0,0,0,0.2);
}

.list-row-status .form-check-input[type="checkbox"]:hover::before,
.list-row-actions .form-check-input[type="checkbox"]:hover::before {
  box-shadow: 0 2px 6px rgba(0,0,0,0.25);
}

.list-row-status .form-check-input[type="checkbox"]:checked::before,
.list-row-actions .form-check-input[type="checkbox"]:checked::before {
  transform: translateX(18px);
}

/* Add Release row */
.list-row-add {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 72px;
  border: 1px solid var(--border-color);
  border-radius: 16px;
  background: transparent;
  color: var(--text-muted);
  text-decoration: none;
  transition: border-color 0.2s ease, color 0.2s ease, background-color 0.2s ease;
}

.list-row-add:hover {
  border-color: var(--highlight);
  color: var(--highlight);
  background-color: var(--hover-bg);
}

.list-row-add-content {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.9375rem;
  font-weight: 500;
}

.list-row-add-content i {
  font-size: 1.25rem;
}

@media (min-width: 1750px) {
  .page-artists .list-view {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (max-width: 1280px) {
  .page-artists .list-view {
    grid-template-columns: 1fr;
  }
}

/* Artist grid cards - square aspect ratio */
.page-artists .grid-card-image {
  aspect-ratio: 1;
}

.list-row {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: var(--spacing-md) var(--spacing-lg);
  background: var(--bg-color);
  border-radius: var(--radius-sm);
  transition:
    outline-color var(--duration-fast) var(--ease-out),
    transform var(--duration-fast) var(--ease-out),
    box-shadow var(--duration-fast) var(--ease-out);
  outline: 2px solid transparent;
  outline-offset: -2px;
}

.list-row:hover {
  outline-color: var(--border-color);
  transform: translateY(-1px);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
}

.list-row:active {
  transform: translateY(0);
  box-shadow: none;
}

.list-row.is-selected {
  outline-color: var(--highlight);
}

.list-row-image {
  width: 48px;
  height: 48px;
  flex-shrink: 0;
  border-radius: 6px;
  overflow: hidden;
}

.list-row-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.list-row-placeholder {
  width: 100%;
  height: 100%;
  background: linear-gradient(145deg, #fad0c4 0%, #ffd1ff 50%, #e0c3fc 100%);
  position: relative;
  overflow: hidden;
}

.list-row-placeholder::after {
  content: '';
  position: absolute;
  inset: 0;
  background: var(--noise-texture);
  opacity: 0.33;
  mix-blend-mode: multiply;
  pointer-events: none;
}

.list-row-content {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 0.125rem;
}

.list-row-name {
  font-size: var(--text-base);
  font-weight: 500;
  color: var(--text-color);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.list-row-artist {
  font-size: var(--text-sm);
  color: var(--text-muted);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.list-row-stats {
  display: flex;
  gap: 0.75rem;
}

/* When stats are a direct child of list-row (old layout) */
.list-row > .list-row-stats {
  flex-shrink: 0;
}

.list-row-stat {
  font-size: var(--text-sm);
  color: var(--text-muted);
  display: flex;
  align-items: center;
  gap: 0.25rem;
}

.list-row-stat i {
  font-size: 0.75rem;
}

.list-row-status {
  flex-shrink: 0;
  padding-right: 0.5rem;
}

.list-row-status .form-check-input {
  margin: 0;
}

/* List row actions container (edit button + toggle) */
.list-row-actions {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-shrink: 0;
  padding-right: 0.5rem;
}

.list-row-actions .form-check-input {
  margin: 0;
}

.list-row-edit-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border: none;
  background: transparent;
  color: var(--text-muted);
  cursor: pointer;
  border-radius: var(--radius-sm);
  transition: all var(--duration-fast) var(--ease-out);
  opacity: 0;
}

.list-row:hover .list-row-edit-btn {
  opacity: 1;
}

.list-row-edit-btn:hover {
  background: var(--bg-secondary);
  color: var(--text-color);
}

.list-row-edit-btn:active {
  transform: scale(0.95);
}

.list-row-edit-btn i {
  font-size: 0.75rem;
  line-height: 1;
  display: block;
}

/* List row delete button */
.list-row-delete-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border: none;
  background: transparent;
  color: var(--text-muted);
  cursor: pointer;
  border-radius: var(--radius-sm);
  transition: all var(--duration-fast) var(--ease-out);
  opacity: 0;
}

.list-row:hover .list-row-delete-btn {
  opacity: 1;
}

.list-row-delete-btn:hover {
  background: rgba(220, 53, 69, 0.1);
  color: #dc3545;
}

.list-row-delete-btn:active {
  transform: scale(0.95);
}

.list-row-delete-btn i {
  font-size: 0.75rem;
  line-height: 1;
  display: block;
}

/* Grid card edit button */
.grid-card-edit-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border: none;
  background: transparent;
  color: var(--text-muted);
  cursor: pointer;
  border-radius: var(--radius-sm);
  transition: all var(--duration-fast) var(--ease-out);
}

.grid-card-edit-btn:hover {
  background: rgba(96, 165, 250, 0.1);
  color: rgb(96, 165, 250);
}

.grid-card-edit-btn:active {
  transform: scale(0.95);
}

.grid-card-edit-btn i {
  font-size: 0.8125rem;
  line-height: 1;
  display: block;
}

/* Grid card delete button */
.grid-card-delete-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border: none;
  background: transparent;
  color: var(--text-muted);
  cursor: pointer;
  border-radius: var(--radius-sm);
  transition: all var(--duration-fast) var(--ease-out);
}

.grid-card-delete-btn:hover {
  background: rgba(220, 53, 69, 0.1);
  color: #dc3545;
}

.grid-card-delete-btn:active {
  transform: scale(0.95);
}

.grid-card-delete-btn i {
  font-size: 0.75rem;
  line-height: 1;
  display: block;
}

/* Floating action button loading state */
.floating-action-btn.is-loading {
  pointer-events: none;
  opacity: 0.7;
}

.floating-action-btn.is-loading i::before {
  content: "\F130"; /* Bootstrap Icons spinner */
  animation: spin 1s linear infinite;
}

/* List row add button (not a link) */
button.list-row-add {
  width: 100%;
  text-align: left;
  cursor: pointer;
}

/* Grid card add button (not a link) */
button.grid-card-add {
  cursor: pointer;
}

/* Responsive: filter bar adjustments */
@media (max-width: 1600px) {
  .filter-bar {
    /* Collapsed sidebar + gap, right sidebar still visible */
    left: calc((var(--panel-inset) + var(--sidebar-collapsed) + var(--panel-inset)) + ((100vw - var(--panel-inset) - var(--sidebar-collapsed) - var(--panel-inset) - var(--right-sidebar-width) - var(--panel-gap) - var(--panel-inset)) / 2));
    transform: translateX(-50%);
  }
}

@media (max-width: 899.98px) {
  .filter-bar {
    left: calc((var(--panel-inset) + var(--sidebar-collapsed) + var(--panel-inset)) + ((100vw - var(--panel-inset) - var(--sidebar-collapsed) - var(--panel-inset) - var(--panel-inset)) / 2));
    transform: translateX(-50%);
    width: 400px;
  }
}

@media (max-width: 576px) {
  .filter-bar {
    width: calc(100% - 80px);
    left: 50%;
    transform: translateX(-50%);
  }

  .filter-bar-options {
    display: none;
  }

  .filter-bar-search {
    height: 40px;
  }

  .list-row-image {
    width: 40px;
    height: 40px;
  }

  .list-row-stats {
    gap: 0.5rem;
  }
}

/* ============================================
   GRID CARDS (shared artists/loudlinks)
   ============================================ */

.page-heading {
  position: relative;
  z-index: 10;
  background: transparent;
}

.grid-container {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 24px;
  padding-bottom: 100px;
  align-content: start;
}

/* Fixed breakpoints - items grow/shrink within columns, then change count */
@media (max-width: 1600px) { .grid-container { grid-template-columns: repeat(4, 1fr); } }
@media (max-width: 1200px) { .grid-container { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 900px) { .grid-container { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 500px) { .grid-container { grid-template-columns: repeat(2, 1fr); } }

.grid-empty {
  grid-column: 1 / -1;
  text-align: center;
  padding: 3rem;
}

.grid-card {
  position: relative;
  background: transparent;
  border: none;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  min-width: 0;
  width: 100%;
}

.grid-card-image {
  position: relative;
  width: 100%;
  aspect-ratio: 1;
  background: var(--bg-secondary);
  border-radius: 6px;
  overflow: hidden;
  transition:
    transform var(--duration-fast) var(--ease-out),
    box-shadow var(--duration-fast) var(--ease-out);
}

/* Hover effects removed for cleaner selection UX */

.grid-card-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Circular image variant for artists */
.grid-card-image-circular {
  border-radius: 50%;
}

.grid-card-image-circular .grid-card-placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--bg-secondary);
}

.grid-card-image-circular .grid-card-placeholder i {
  font-size: 2.5rem;
  color: var(--text-muted);
}

.grid-card-placeholder {
  width: 100%;
  height: 100%;
  background: linear-gradient(145deg, #fad0c4 0%, #ffd1ff 50%, #e0c3fc 100%);
  position: relative;
  overflow: hidden;
}

.grid-card-placeholder::after {
  content: '';
  position: absolute;
  inset: 0;
  background: var(--noise-texture);
  opacity: 0.33;
  mix-blend-mode: multiply;
  pointer-events: none;
}

/* Footer row with info and toggle */
.grid-card-footer {
  display: flex;
  align-items: flex-start;
  gap: var(--spacing-sm);
  padding: var(--spacing-sm) 0;
}

.grid-card-info {
  display: flex;
  flex-direction: column;
  gap: 0.125rem;
  flex: 1;
  min-width: 0;
}

.grid-card-toggle {
  flex-shrink: 0;
  padding-top: 2px;
}

.grid-card-actions {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-shrink: 0;
}

.grid-card-toggle .form-check-input,
.grid-card-actions .form-check-input {
  width: 36px;
  height: 20px;
  cursor: pointer;
  -webkit-appearance: none;
  appearance: none;
  background-color: var(--border-color);
  background-image: none !important;
  border: none;
  border-radius: 10px;
  position: relative;
  transition: background-color 0.2s ease, transform var(--duration-instant) var(--ease-out);
  margin: 0;
}

.grid-card-toggle .form-check-input:hover,
.grid-card-actions .form-check-input:hover {
  transform: scale(1.08);
}

.grid-card-toggle .form-check-input:active,
.grid-card-actions .form-check-input:active {
  transform: scale(0.95);
}

.grid-card-toggle .form-check-input:checked,
.grid-card-actions .form-check-input:checked {
  background-color: var(--highlight);
}

.grid-card-toggle .form-check-input::before,
.grid-card-actions .form-check-input::before {
  content: '';
  position: absolute;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: white;
  top: 2px;
  left: 2px;
  transition: transform 0.2s cubic-bezier(0.34, 1.56, 0.64, 1), box-shadow 0.15s ease;
  box-shadow: 0 1px 3px rgba(0,0,0,0.2);
}

.grid-card-toggle .form-check-input:hover::before,
.grid-card-actions .form-check-input:hover::before {
  box-shadow: 0 2px 6px rgba(0,0,0,0.25);
}

.grid-card-toggle .form-check-input:checked::before,
.grid-card-actions .form-check-input:checked::before {
  transform: translateX(16px);
}

/* Dark mode toggle switches - use blue for ON state */
[data-theme="dark"] .list-row-status .form-check-input[type="checkbox"]:checked,
[data-theme="dark"] .list-row-actions .form-check-input[type="checkbox"]:checked,
[data-theme="dark"] .grid-card-toggle .form-check-input:checked,
[data-theme="dark"] .grid-card-actions .form-check-input:checked {
  background-color: #0d6efd;
}

.grid-card-title {
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--text-color);
  margin: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.grid-card-artist {
  font-size: var(--text-xs);
  color: var(--text-muted);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.grid-card-stats {
  display: flex;
  gap: 0.5rem;
  flex-shrink: 0;
}

.grid-card-stat {
  font-size: var(--text-xs);
  color: var(--text-muted);
  display: flex;
  align-items: center;
  gap: 0.2rem;
}

.grid-card-stat i {
  font-size: 0.65rem;
}

/* Status indicator - bottom right of image */
.grid-card-status {
  position: absolute;
  bottom: 0.5rem;
  right: 0.5rem;
  z-index: 3;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--text-color);
}

.grid-card-status.is-active {
  background: #22c55e;
}

/* Clickable rows */
.clickable-row {
  cursor: pointer;
}

.clickable-row:hover {
  /* Removed hover effect */
}

/* Clickable grid cards */
.grid-card-clickable {
  cursor: pointer;
}

/* Selection handled by .grid-card.is-selected .grid-card-image */

/* Add new release card - artwork size only */
.grid-card-add {
  aspect-ratio: 1;
  border: 1px solid var(--border-color);
  border-radius: 6px;
  background: transparent;
  text-decoration: none;
  cursor: pointer;
  transition: border-color 0.15s ease, background 0.15s ease;
  position: relative;
}

.grid-card-add:hover {
  border-color: var(--text-muted);
  background: var(--bg-secondary);
}

.grid-card-add-content {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  color: var(--text-muted);
}

.grid-card-add-content i {
  font-size: 2rem;
}

.grid-card-add-content span {
  font-size: var(--text-sm);
  font-weight: 500;
}

.grid-card-add:hover .grid-card-add-content {
  color: var(--text-color);
}

/* Action button - bottom right of grid card */
.grid-card-action-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: var(--primary-color);
  color: #fff;
  font-size: 0.75rem;
  text-decoration: none;
  transition: transform 0.15s ease, background 0.15s ease;
}

.grid-card-action-btn:hover {
  transform: scale(1.1);
  background: var(--primary-hover);
  color: #fff;
}

.grid-card-action-btn.is-inactive {
  background: var(--text-muted);
  opacity: 0.5;
}

.grid-card-action-btn.is-inactive:hover {
  background: var(--text-muted);
  transform: none;
}

/* Dark mode grid cards */
[data-theme="dark"] .grid-card-image {
  background: #1a1a1a;
}

/* ============================================
   ORBITAL VIEW (shared artists/loudlinks)
   ============================================ */

.orbital-container {
  position: fixed;
  top: 0;
  bottom: 0;
  left: calc(var(--panel-inset) + var(--sidebar-collapsed) + var(--panel-gap));
  right: calc(var(--panel-inset) + var(--right-sidebar-width) + var(--panel-gap));
  z-index: 5;
  overflow: hidden;
  background-color: transparent;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Collapsed sidebar, right sidebar still visible */
@media (max-width: 1600px) {
  .orbital-container {
    left: calc(var(--panel-inset) + var(--sidebar-collapsed) + var(--panel-inset));
    right: calc(var(--panel-inset) + var(--right-sidebar-width) + var(--panel-gap));
  }
}

/* Mobile - no sidebars */
@media (max-width: 899.98px) {
  .orbital-container {
    left: var(--panel-inset);
    right: var(--panel-inset);
  }
}

#orbitalCanvas {
  width: 100%;
  height: 100%;
  display: block;
  cursor: grab;
}

#orbitalCanvas:active {
  cursor: grabbing;
}

.orbital-tooltip {
  position: fixed;
  padding: 0.5rem 1rem;
  background: var(--bg-color);
  border-radius: 8px;
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--text-color);
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.2s ease;
  box-shadow: 0 4px 12px rgba(0,0,0,0.15);
  z-index: 100;
}

.orbital-tooltip.visible {
  opacity: 1;
}

[data-theme="dark"] .orbital-tooltip {
  background: var(--bg-secondary);
}

.cinematic-toggle {
  position: absolute;
  bottom: 20px;
  right: 20px;
  z-index: 100;
  background: rgba(255,255,255,0.9);
  border: 1px solid rgba(0,0,0,0.1);
  padding: 8px 12px;
  border-radius: 8px;
  cursor: pointer;
  transition: all 0.3s ease;
}

.cinematic-toggle:hover {
  background: rgba(255,255,255,1);
  transform: scale(1.05);
}

.cinematic-toggle.active {
  background: #0d6efd;
  color: white;
  border-color: #0d6efd;
}

[data-theme="dark"] .cinematic-toggle {
  background: rgba(30,30,30,0.9);
  border-color: rgba(255,255,255,0.1);
  color: white;
}

[data-theme="dark"] .cinematic-toggle:hover {
  background: rgba(50,50,50,1);
}

[data-theme="dark"] .cinematic-toggle.active {
  background: #0d6efd;
  border-color: #0d6efd;
}

/* ============================================
   ANALYTICS
   Stat cards, chart cards, loading states
   ============================================ */

/* Refresh button spinner */
#refreshBtn.is-loading .bi-arrow-clockwise {
  animation: spin 1.5s linear infinite;
}

/* ============================================
   ANALYTICS - Clean design with panels
   ============================================ */

/* Stat cards - panels with lighter typography */
.stat-card {
  border-radius: 12px;
  border: none;
  background: var(--bg-color);
  box-shadow: none;
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
}

[data-theme="dark"] .stat-card {
  background: #181818;
  border: none;
}

.stat-card-body {
  padding: 1.5rem;
  flex: 1;
  display: flex;
  align-items: flex-start;
  width: 100%;
  background: transparent;
}

.stat-card-body > .d-flex,
.stat-card-body > div {
  width: 100%;
}

h6.stat-title,
.stat-title {
  font-size: var(--text-xs);
  font-weight: 500;
  color: var(--text-muted);
  margin-bottom: 0.5rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.stat-number {
  font-size: 2.5rem;
  font-weight: 300;
  color: var(--text-color);
  line-height: 1.1;
  letter-spacing: -0.02em;
}

.stat-subtitle {
  display: none;
}

.stat-icon {
  display: none;
}

/* Trend indicators */
.stat-trend {
  margin-top: 0.75rem;
  font-size: var(--text-xs);
}

.stat-trend small {
  font-size: var(--text-xs);
  font-weight: 500;
}

.stat-trend .text-success {
  color: #22c55e !important;
}

.stat-trend .text-danger {
  color: var(--text-muted) !important;
}

.stat-trend .text-muted {
  color: var(--text-tertiary) !important;
}

/* Horizontal layout for summary stats */
.summary-stats-container {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
}

.stat-wrapper {
  flex: 1;
  min-width: 200px;
}

@media (max-width: 900px) {
  .summary-stats-container {
    flex-direction: column;
  }

  .stat-wrapper {
    min-width: 100%;
  }

  .stat-number {
    font-size: 2rem;
  }
}

@media (min-width: 769px) and (max-width: 1024px) {
  .stat-wrapper {
    flex: 1 1 calc(50% - 0.5rem);
    min-width: calc(50% - 0.5rem);
  }
}

@media (min-width: 1025px) {
  .stat-wrapper {
    flex: 1 1 calc(25% - 0.75rem);
    min-width: calc(25% - 0.75rem);
  }
}

/* Chart cards - panels */
.chart-card {
  background: var(--bg-color);
  border-radius: 12px;
  border: none;
  box-shadow: none;
  height: 100%;
}

[data-theme="dark"] .chart-card {
  background: #181818;
  border: none;
}

.chart-header {
  padding: 1.25rem 1.25rem 0.75rem 1.25rem;
  border-bottom: none;
  background: transparent;
}

.chart-title {
  font-size: 1rem;
  font-weight: 500;
  margin-bottom: 0;
  color: var(--text-color);
}

.chart-title i {
  display: none;
}

.chart-header small {
  display: none;
}

.chart-body {
  padding: 1rem 1.25rem 1.25rem 1.25rem;
  background: transparent;
}

/* Prevent white flash on chart load/resize - AG Charts elements */
.chart-body div[id*="Chart"],
.chart-body div[id*="Chart"] *,
.chart-body .ag-chart-wrapper,
.chart-body .ag-charts-wrapper {
  background: transparent !important;
  background-color: transparent !important;
}

/* Match chart card background to prevent canvas white flash */
.chart-body canvas {
  background: var(--bg-color) !important;
}

[data-theme="dark"] .chart-body canvas {
  background: #181818 !important;
}

@media (max-width: 900px) {
  .stat-number {
    font-size: 1.875rem;
  }

  .stat-icon {
    font-size: 2rem;
  }

  .chart-body div[id*="Chart"] {
    height: 300px !important;
  }
}

#noDataMessage {
  background: transparent;
  border-radius: 12px;
  border: 2px dashed var(--border-color);
}

[data-theme="dark"] #noDataMessage {
  border-color: #444;
}

/* Analytics tabs */
.analytics-tabs {
  display: flex;
  gap: 4px;
  background: rgba(0, 0, 0, 0.03);
  border-radius: 8px;
  padding: 3px;
  width: fit-content;
}

.analytics-tab {
  padding: 6px 16px;
  border: none;
  border-radius: 6px;
  background: transparent;
  color: var(--text-muted);
  font-size: 13px;
  font-weight: 500;
  font-family: inherit;
  cursor: pointer;
  transition: all 0.12s ease;
}

.analytics-tab:hover { color: var(--text-color); }

.analytics-tab.is-active {
  background: var(--bg-color);
  color: var(--text-color);
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08);
}

[data-theme="dark"] .analytics-tabs { background: rgba(255, 255, 255, 0.04); }
[data-theme="dark"] .analytics-tab.is-active { background: rgba(255, 255, 255, 0.08); }

.analytics-tabs {
  position: sticky;
  top: 0;
  z-index: 10;
}

.analytics-section {
  scroll-margin-top: 60px;
}

.analytics-section-title {
  font-size: 14px;
  font-weight: 600;
  color: var(--text-muted);
  margin: 24px 0 12px 0;
  padding-bottom: 8px;
  border-bottom: 1px solid rgba(128, 128, 128, 0.1);
  display: flex;
  align-items: center;
  gap: 8px;
}

.analytics-section-title i {
  font-size: 16px;
  opacity: 0.6;
}

/* Analytics Summary Sidebar */
.analytics-summary {
  padding: 16px;
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.analytics-summary-item {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.analytics-summary-label {
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--text-muted);
  opacity: 0.7;
}

.analytics-summary-value {
  display: flex;
  align-items: center;
  gap: 10px;
}

.analytics-summary-artwork {
  width: 40px;
  height: 40px;
  border-radius: 6px;
  object-fit: cover;
  flex-shrink: 0;
}

.analytics-summary-artwork--round {
  border-radius: 50%;
}

.analytics-summary-name {
  font-size: 14px;
  font-weight: 600;
  color: var(--text-color);
  line-height: 1.3;
}

.analytics-summary-stat {
  font-size: 12px;
  color: var(--text-muted);
}

.analytics-summary-big {
  font-size: 28px;
  font-weight: 700;
  color: var(--text-color);
  line-height: 1.1;
}

.analytics-summary-sub {
  font-size: 11px;
  color: var(--text-muted);
}

/* Mode Banner — Edit / Preview / Version */
.sidebar-mode-banner {
  display: none !important;
  position: absolute;
  bottom: 12px;
  left: 12px;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 6px 12px;
  font-size: 11px;
  font-weight: 500;
  z-index: 10;
  border-radius: 8px;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  transition: all 0.15s ease;
  pointer-events: auto;
}

.sidebar-preview-panel {
  position: relative;
}

.sidebar-mode-label {
  display: flex;
  align-items: center;
  gap: 6px;
}

.sidebar-mode-label i {
  font-size: 12px;
}

.sidebar-mode--edit {
  background: rgba(0, 0, 0, 0.4);
  color: rgba(255, 255, 255, 0.5);
}

.sidebar-mode--preview {
  background: rgba(0, 0, 0, 0.6);
  color: rgba(72, 219, 251, 0.9);
}

.sidebar-mode--version {
  background: rgba(0, 0, 0, 0.6);
  color: rgba(250, 204, 21, 0.9);
}

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

.sidebar-mode-btn {
  padding: 3px 10px;
  border: none;
  border-radius: 4px;
  font-size: 10px;
  font-weight: 600;
  font-family: inherit;
  cursor: pointer;
  transition: all 0.12s ease;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

.sidebar-mode-exit {
  background: rgba(255, 255, 255, 0.08);
  color: rgba(255, 255, 255, 0.6);
}

.sidebar-mode-exit:hover {
  background: rgba(255, 255, 255, 0.15);
  color: white;
}

.sidebar-mode-restore {
  background: rgba(76, 175, 80, 0.15);
  color: #4ade80;
}

.sidebar-mode-restore:hover {
  background: rgba(76, 175, 80, 0.25);
}

/* Analytics AI Assistant */
.analytics-ai {
  position: relative;
}

.analytics-ai-input-wrap {
  display: flex;
  align-items: center;
  background: var(--card-bg, rgba(0, 0, 0, 0.03));
  border: 1px solid rgba(128, 128, 128, 0.15);
  border-radius: 10px;
  padding: 0 12px;
  transition: border-color 0.15s ease;
}

.analytics-ai-input-wrap:focus-within {
  border-color: rgba(96, 165, 250, 0.5);
}

.analytics-ai-icon {
  color: var(--text-muted);
  font-size: 14px;
  opacity: 0.5;
  margin-right: 8px;
}

.analytics-ai-input {
  flex: 1;
  border: none;
  background: transparent;
  padding: 10px 0;
  font-size: 13px;
  font-family: inherit;
  color: var(--text-color);
  outline: none;
}

.analytics-ai-input::placeholder {
  color: var(--text-muted);
  opacity: 0.6;
}

.analytics-ai-send {
  border: none;
  background: transparent;
  color: var(--text-muted);
  cursor: pointer;
  padding: 4px 0 4px 8px;
  font-size: 16px;
  transition: color 0.15s ease;
}

.analytics-ai-send:hover {
  color: var(--text-color);
}

.analytics-ai-response {
  margin-top: 8px;
  padding: 12px 16px;
  background: var(--card-bg, rgba(0, 0, 0, 0.03));
  border: 1px solid rgba(128, 128, 128, 0.1);
  border-radius: 10px;
  font-size: 13px;
  line-height: 1.6;
  color: var(--text-color);
  position: relative;
}

.analytics-ai-response .ai-thinking {
  color: var(--text-muted);
  font-style: italic;
}

.analytics-ai-response .ai-answer {
  white-space: pre-line;
}

.analytics-ai-response .ai-close {
  position: absolute;
  top: 8px;
  right: 8px;
  background: none;
  border: none;
  color: var(--text-muted);
  cursor: pointer;
  font-size: 14px;
  opacity: 0.5;
}

.analytics-ai-response .ai-close:hover {
  opacity: 1;
}

.ai-feedback {
  display: flex;
  gap: 4px;
  margin-top: 8px;
}

.ai-feedback-btn {
  background: none;
  border: none;
  color: var(--text-muted);
  cursor: pointer;
  font-size: 13px;
  padding: 2px 6px;
  opacity: 0.5;
  transition: all 0.15s ease;
}

.ai-feedback-btn:hover {
  opacity: 1;
}

[data-theme="dark"] .analytics-ai-input-wrap {
  background: rgba(255, 255, 255, 0.04);
  border-color: rgba(255, 255, 255, 0.08);
}

[data-theme="dark"] .analytics-ai-response {
  background: rgba(255, 255, 255, 0.04);
  border-color: rgba(255, 255, 255, 0.06);
}

/* Analytics filter card */
.analytics-filter-card {
  background: var(--bg-color);
  box-shadow: none;
  border: none;
}

[data-theme="dark"] .analytics-filter-card {
  background: #181818;
  border: none;
}

.analytics-filter-card .card-header {
  background: transparent;
  padding-top: 1.25rem;
  border-bottom: none;
}

/* Top content styling */
#topContentContainer {
  background: transparent;
  border-radius: 8px;
  min-height: 200px;
}

/* Top content items - override Bootstrap bg-white */
#topContentContainer .bg-white {
  background: transparent !important;
  border-color: var(--border-color) !important;
}

[data-theme="dark"] #topContentContainer .bg-white {
  border: none !important;
}

#topContentContainer .text-dark {
  color: var(--text-color) !important;
}

#topContentContainer .badge {
  font-size: 0.75rem;
}

/* Analytics loading states */
.stat-wrapper,
.chart-card,
#noDataMessage {
  opacity: 1;
}

/* Isolate chart rendering from main thread scroll */
.chart-card,
.chart-body {
  contain: layout style;
}

/* Poll status indicator */
#pollStatus {
  transition: background-color 0.3s ease, color 0.3s ease;
}

#pollStatus .bi-circle-fill {
  animation: pulse-dot 2s ease-in-out infinite;
}

@keyframes pulse-dot {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.4; }
}

#pollStatus.bg-success .bi-circle-fill {
  animation-duration: 0.5s;
}

#pollStatus.bg-danger .bi-circle-fill {
  animation-duration: 0.3s;
}

#analyticsContent.is-fading-out .stat-wrapper,
#analyticsContent.is-fading-out .chart-card,
#analyticsContent.is-fading-out #noDataMessage {
  opacity: 0.3;
  transition: opacity 100ms ease-out;
}

@keyframes breathe {
  0%, 100% { opacity: 0.4; }
  50% { opacity: 0.15; }
}

#analyticsContent.is-loading {
  pointer-events: none;
  position: relative;
}

#analyticsContent.is-loading .stat-wrapper,
#analyticsContent.is-loading .chart-card,
#analyticsContent.is-loading #noDataMessage {
  animation: breathe 1.5s ease-in-out infinite;
}

#analyticsContent.is-revealing .stat-wrapper,
#analyticsContent.is-revealing .chart-card,
#analyticsContent.is-revealing #noDataMessage {
  transition: opacity 500ms ease-out;
}

/* Analytics loading overlay - prominent indicator */
.analytics-loading-overlay {
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 100;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.75rem;
  padding: 1.5rem 2rem;
  background: var(--bg-card);
  border-radius: var(--border-radius-lg);
  box-shadow: var(--shadow-lg);
  opacity: 0;
  visibility: hidden;
  transition: opacity 150ms ease, visibility 150ms ease;
}

.analytics-loading-overlay.is-visible {
  opacity: 1;
  visibility: visible;
}

.analytics-loading-spinner {
  width: 32px;
  height: 32px;
  border: 3px solid var(--bg-tertiary);
  border-top-color: var(--highlight);
  border-radius: 50%;
  animation: spin 0.8s linear infinite;
}

.analytics-loading-text {
  font-size: 0.875rem;
  color: var(--text-secondary);
}

/* ============================================
   DASHBOARD CANVAS - Drag & Drop Layout
   ============================================ */

.dashboard-canvas {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.dashboard-row {
  display: flex;
  gap: 1rem;
}

.dashboard-panel {
  flex: 1;
  min-width: 0;
  cursor: grab;
  transition: opacity 0.15s ease, transform 0.15s ease;
  position: relative;
  border-radius: 12px;
}

.dashboard-panel:active {
  cursor: grabbing;
}

.dashboard-panel.is-dragging {
  opacity: 0.25;
}

.dashboard-canvas.is-dragging .dashboard-panel:not(.is-dragging) {
  transition: transform 0.15s ease;
}

/* Vertical drop indicator (between rows) */
.dashboard-drop-indicator-v {
  height: 4px;
  border-radius: 2px;
  background: linear-gradient(90deg, #48dbfb, #4ade80, #48dbfb);
  box-shadow: 0 0 12px rgba(72, 219, 251, 0.4);
  pointer-events: none;
  flex-shrink: 0;
}

/* Horizontal drop indicator (side of panel) */
.dashboard-drop-indicator-h {
  position: absolute;
  top: 8px;
  bottom: 8px;
  width: 4px;
  border-radius: 2px;
  background: linear-gradient(180deg, #48dbfb, #4ade80, #48dbfb);
  box-shadow: 0 0 12px rgba(72, 219, 251, 0.4);
  z-index: 20;
  pointer-events: none;
}

.dashboard-drop-indicator-h.left {
  left: -3px;
}

.dashboard-drop-indicator-h.right {
  right: -3px;
}

/* Summary stats adaptation based on column count */
.dashboard-row[data-columns="1"] .dashboard-panel[data-panel-id="summary-stats"] .summary-stats-container {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
}

.dashboard-row[data-columns="2"] .dashboard-panel[data-panel-id="summary-stats"] .summary-stats-container {
  display: grid !important;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 1fr 1fr;
  gap: 0;
  height: 100%;
}

.dashboard-row[data-columns="2"] .dashboard-panel[data-panel-id="summary-stats"] .stat-wrapper {
  min-width: 0 !important;
  flex: none !important;
}

.dashboard-row[data-columns="2"] .dashboard-panel[data-panel-id="summary-stats"] .stat-card {
  border-radius: 0;
  height: 100%;
}

.dashboard-row[data-columns="2"] .dashboard-panel[data-panel-id="summary-stats"] .stat-wrapper:first-child .stat-card {
  border-top-left-radius: 12px;
}

.dashboard-row[data-columns="2"] .dashboard-panel[data-panel-id="summary-stats"] .stat-wrapper:nth-child(2) .stat-card {
  border-top-right-radius: 12px;
}

.dashboard-row[data-columns="2"] .dashboard-panel[data-panel-id="summary-stats"] .stat-wrapper:nth-child(3) .stat-card {
  border-bottom-left-radius: 12px;
}

.dashboard-row[data-columns="2"] .dashboard-panel[data-panel-id="summary-stats"] .stat-wrapper:nth-child(4) .stat-card {
  border-bottom-right-radius: 12px;
}

.dashboard-row[data-columns="3"] .dashboard-panel[data-panel-id="summary-stats"] .summary-stats-container {
  display: grid !important;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 1fr 1fr;
  gap: 0;
  height: 100%;
}

.dashboard-row[data-columns="3"] .dashboard-panel[data-panel-id="summary-stats"] .stat-wrapper {
  min-width: 0 !important;
  flex: none !important;
}

.dashboard-row[data-columns="3"] .dashboard-panel[data-panel-id="summary-stats"] .stat-card {
  border-radius: 0;
  height: 100%;
}

.dashboard-row[data-columns="3"] .dashboard-panel[data-panel-id="summary-stats"] .stat-wrapper:first-child .stat-card {
  border-top-left-radius: 12px;
}

.dashboard-row[data-columns="3"] .dashboard-panel[data-panel-id="summary-stats"] .stat-wrapper:nth-child(2) .stat-card {
  border-top-right-radius: 12px;
}

.dashboard-row[data-columns="3"] .dashboard-panel[data-panel-id="summary-stats"] .stat-wrapper:nth-child(3) .stat-card {
  border-bottom-left-radius: 12px;
}

.dashboard-row[data-columns="3"] .dashboard-panel[data-panel-id="summary-stats"] .stat-wrapper:nth-child(4) .stat-card {
  border-bottom-right-radius: 12px;
}

.dashboard-row[data-columns="3"] .dashboard-panel[data-panel-id="summary-stats"] .stat-number {
  font-size: 1.5rem;
}

.dashboard-row[data-columns="4"] .dashboard-panel[data-panel-id="summary-stats"] .summary-stats-container {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.dashboard-row[data-columns="4"] .dashboard-panel[data-panel-id="summary-stats"] .stat-wrapper {
  min-width: 0;
}

.dashboard-row[data-columns="4"] .dashboard-panel[data-panel-id="summary-stats"] .stat-number {
  font-size: 1.25rem;
}

/* Mobile: stack rows, disable drag */
@media (max-width: 900px) {
  .dashboard-row {
    flex-direction: column;
  }

  .dashboard-panel {
    cursor: default;
  }
}

/* ============================================
   CALENDAR
   Schedule, grid, zoom, dark mode
   ============================================ */

/* Calendar top bar - centered date indicator as FAB */
.calendar-top-bar {
  position: fixed;
  top: calc(10px + 1rem);
  /* Center in main content area - no transition for instant response */
  --cal-left: calc(var(--sidebar-collapsed, 72px) + var(--panel-inset, 10px) * 2);
  --cal-right: calc(100vw - var(--panel-inset, 10px));
  left: calc((var(--cal-left) + var(--cal-right)) / 2);
  transform: translateX(-50%);
  z-index: 99;
  pointer-events: none;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

/* Adjust calendar top bar when right sidebar is open */
body.right-sidebar-open .calendar-top-bar {
  --cal-right: calc(100vw - var(--panel-inset, 10px) - var(--right-sidebar-width, 380px) - var(--panel-gap, 10px));
}

/* Sidebar always mini — no wide-screen override needed */

/* Today button - pill with circle icon and label */
.calendar-today-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  height: 40px;
  padding: 0 1rem 0 0.75rem;
  font-size: 1rem;
  color: var(--text-muted);
  background: var(--bg-color);
  border: none;
  border-radius: 9999px;
  cursor: pointer;
  transition: color 0.15s ease, background-color 0.15s ease;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
  pointer-events: auto;
}

.calendar-today-label {
  font-size: var(--text-sm);
  font-weight: 500;
}

.calendar-today-btn:hover {
  color: var(--text-color);
  background: var(--bg-secondary);
}

.calendar-today-btn.is-today {
  color: white;
  background: var(--text-color);
}

.calendar-today-btn.is-today:hover {
  opacity: 0.85;
}

[data-theme="dark"] .calendar-today-btn {
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
}

[data-theme="dark"] .calendar-today-btn.is-today {
  background: white;
  color: #1a1a1a;
}

.calendar-top-btn:hover {
  background: var(--bg-secondary);
  border-color: var(--text-muted);
}

/* ===== FLOATING UI ===== */
.floating-ui,
.ve-toast {
  /* Center within main content area - matches main.main-content left edge */
  --float-left: calc(var(--panel-inset, 10px) + var(--sidebar-collapsed, 72px) + var(--panel-gap, 20px));
  --float-right: calc(100vw - var(--panel-inset, 10px));
  left: calc((var(--float-left) + var(--float-right)) / 2);
}

.floating-ui {
  position: fixed;
  bottom: 2rem;
  transform: translateX(-50%);
  display: flex;
  align-items: center;
  gap: 0.75rem;
  z-index: 100;
}

/* Adjust when right sidebar is open */
body.right-sidebar-open .floating-ui,
body.right-sidebar-open .ve-toast {
  --float-right: calc(100vw - var(--panel-inset, 10px) - var(--right-sidebar-width, 390px) - var(--panel-gap, 20px));
}

/* Sidebar always mini — no wide-screen float override needed */

/* Mobile - no sidebars */
@media (max-width: 899.98px) {
  .floating-ui,
  .ve-toast {
    --float-left: var(--panel-inset, 10px);
    --float-right: calc(100vw - var(--panel-inset, 10px));
  }
}

.floating-pill {
  display: flex;
  align-items: center;
  gap: 0.25rem;
  background: var(--bg-color);
  border: 1px solid var(--border-color);
  border-radius: 2rem;
  padding: 0.375rem 0.5rem;
}

.floating-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 36px;
  min-width: 36px;
  padding: 0 0.75rem;
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--text-muted);
  background: transparent;
  border: none;
  border-radius: 18px;
  cursor: pointer;
  transition: background-color 0.15s ease, color 0.15s ease;
}

.floating-btn:hover {
  background: var(--bg-secondary);
  color: var(--text-color);
}

.floating-btn.active {
  background: var(--text-color);
  color: var(--bg-color);
}

.floating-btn i {
  font-size: 1rem;
}

.floating-pill-divider {
  width: 1px;
  height: 20px;
  background: var(--border-color);
  margin: 0 0.25rem;
}

/* Hide list view button on desktop - mobile only */
#listViewBtn {
  display: none;
}

@media (max-width: 768px) {
  #listViewBtn {
    display: flex;
  }
}

.floating-dropdown {
  position: relative;
}

.floating-dropdown-menu {
  position: absolute;
  bottom: calc(100% + 8px);
  right: 0;
  background: var(--bg-color);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-md);
  padding: 0.375rem;
  min-width: 140px;
  box-shadow: 0 4px 12px rgba(0,0,0,0.15);
  opacity: 0;
  visibility: hidden;
  transform: translateY(8px);
  transition: opacity 0.15s ease, transform 0.15s ease, visibility 0.15s ease;
  z-index: 100;
}

.floating-dropdown.is-open .floating-dropdown-menu {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.floating-dropdown-item {
  display: block;
  width: 100%;
  padding: 0.5rem 0.75rem;
  font-size: var(--text-sm);
  color: var(--text-color);
  background: transparent;
  border: none;
  border-radius: var(--radius-sm);
  text-align: left;
  cursor: pointer;
  transition: background 0.15s ease;
}

.floating-dropdown-item:hover {
  background: var(--bg-secondary);
}

.floating-dropdown-item.active {
  background: var(--bg-secondary);
  font-weight: 500;
}

.floating-divider {
  width: 1px;
  height: 24px;
  background: var(--border-color);
  margin: 0 0.25rem;
}

.floating-zoom {
  display: flex;
  align-items: center;
  gap: 0.25rem;
}

.floating-zoom-level {
  font-size: var(--text-xs);
  font-weight: 600;
  color: var(--text-muted);
  min-width: 44px;
  text-align: center;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

/* Hide zoom controls in schedule view */
.zoom-only {
  display: flex;
}

body.schedule-active .zoom-only {
  display: none;
}

/* Floating action button (bottom right, expands on hover) */
.floating-action-btn {
  position: fixed;
  bottom: 2rem;
  right: 2rem;
  height: 48px;
  min-width: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  background: var(--text-color);
  color: var(--bg-color);
  border: none;
  border-radius: 24px;
  padding: 0 14px;
  cursor: pointer;
  z-index: 100;
  transition: min-width 0.15s ease, padding 0.15s ease, gap 0.15s ease;
  text-decoration: none;
  overflow: hidden;
}

.floating-action-btn:hover {
  min-width: auto;
  padding: 0 20px 0 16px;
  gap: 0.5rem;
  color: var(--bg-color);
}

.floating-action-btn i {
  font-size: 1.25rem;
  flex-shrink: 0;
}

.floating-action-btn span {
  font-size: var(--text-sm);
  font-weight: 500;
  white-space: nowrap;
  opacity: 0;
  max-width: 0;
  overflow: hidden;
  transition: opacity 0.15s ease, max-width 0.15s ease;
}

.floating-action-btn:hover span {
  opacity: 1;
  max-width: 120px;
}

[data-theme="dark"] .floating-action-btn {
  background: #fff;
  color: #000;
}

[data-theme="dark"] .floating-action-btn:hover {
  background: #f0f0f0;
  color: #000;
}

/* Floating action bar - groups pill controls with FAB at bottom */
.floating-action-bar {
  position: fixed;
  bottom: 2rem;
  right: 2rem;
  display: flex;
  align-items: center;
  gap: 0.75rem;
  z-index: 100;
}

.floating-action-bar .floating-pill {
  position: static;
  bottom: auto;
  left: auto;
  transform: none;
}

.floating-action-bar .floating-action-btn {
  position: static;
  bottom: auto;
  right: auto;
}

/* Circular list row images for artists */
.list-row-image-circular {
  border-radius: 50%;
}

.list-row-image-circular .list-row-placeholder {
  border-radius: 50%;
}

.calendar-month-indicator {
  display: inline-flex;
  align-items: center;
  height: 40px;
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--text-color);
  background: var(--bg-color);
  padding: 0 1.25rem;
  border-radius: 50px;
  white-space: nowrap;
  pointer-events: auto;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
  pointer-events: auto;
}

/* Hide zoom controls in schedule view */
.zoom-only {
  display: flex;
}

/* Active period - full opacity, non-active faded */
.grid-day {
  opacity: 0.5;
}

.grid-day.active-period {
  opacity: 1;
}

.grid-day.today {
  opacity: 1;
}

/* Scroll-based fading for distant content - grid view only */
.grid-day.faded {
  opacity: 0.7;
}

.grid-day.semi-faded {
  opacity: 0.85;
}

/* Smooth transitions for all states */
.grid-day {
  transition: opacity 0.4s ease, background-color 0.3s ease, border-color 0.3s ease;
}

.schedule-day,
.schedule-event {
  transition: background-color 0.3s ease, border-color 0.3s ease;
}

@media (max-width: 899.98px) {
  .calendar-top-bar {
    --cal-left: var(--panel-inset, 10px);
    --cal-right: calc(100vw - var(--panel-inset, 10px));
    left: calc((var(--cal-left) + var(--cal-right)) / 2);
  }

  .calendar-month-indicator {
    font-size: var(--text-xs);
    padding: 0 1rem;
    height: 36px;
  }

  .calendar-today-btn {
    height: 36px;
    padding: 0 0.75rem 0 0.5rem;
    gap: 0.375rem;
  }

  .calendar-today-label {
    font-size: var(--text-xs);
  }

  .floating-ui {
    left: 50%;
    bottom: calc(12px + env(safe-area-inset-bottom));
    gap: 0.5rem;
  }

  .floating-pill {
    height: 56px;
    padding: 0 4px;
    border-radius: 28px;
    gap: 4px;
  }

  .floating-btn {
    width: 48px;
    height: 48px;
    min-width: 48px;
    padding: 0;
    border-radius: 50%;
  }

  .floating-btn i {
    font-size: 1.25rem;
  }

  .floating-divider {
    height: 28px;
  }

  .floating-action-btn {
    bottom: calc(12px + env(safe-area-inset-bottom));
    right: 12px;
    left: auto;
    transform: none;
    height: 48px;
    min-width: 48px;
    padding: 0 14px;
    border-radius: 24px;
  }

  .floating-action-btn i {
    font-size: 1.25rem;
  }

  .floating-action-btn:hover {
    padding: 0 18px 0 14px;
  }
}

/* Scroll container fills parent (gaps handled by main-content positioning) */
.calendar-scroll-container {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  touch-action: pan-y; /* Allow scroll but capture pinch for custom zoom */
  overflow-y: auto;
  overflow-x: hidden;
  cursor: grab;
}

.calendar-scroll-container:active {
  cursor: grabbing;
}

/* Custom scrollbar with rounded corners */
.calendar-scroll-container {
  scrollbar-width: thin;
  scrollbar-color: var(--border-color) transparent;
}

.calendar-scroll-container::-webkit-scrollbar {
  width: 8px;
}

.calendar-scroll-container::-webkit-scrollbar-track {
  background: transparent;
}

.calendar-scroll-container::-webkit-scrollbar-thumb {
  background: var(--border-color);
  border-radius: 4px;
}

.calendar-scroll-container::-webkit-scrollbar-thumb:hover {
  background: var(--text-muted);
}

/* Hide scrollbar for non-day views */
.calendar-scroll-container.hide-scrollbar {
  scrollbar-width: none;
  -ms-overflow-style: none;
}

.calendar-scroll-container.hide-scrollbar::-webkit-scrollbar {
  display: none;
}

.calendar-container {
  position: relative;
  min-height: 100%;
  height: 100%;
}

.calendar-loading {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 4rem;
}

.calendar-empty {
  text-align: center;
  padding: 4rem 2rem;
  color: #9ca3af;
}

.calendar-empty i {
  font-size: 3rem;
  margin-bottom: 1rem;
  display: block;
}

.calendar-empty p {
  margin: 0;
  font-size: 1.1rem;
  color: var(--text-muted);
}

/* ===== SCHEDULE VIEW (events only) ===== */
.calendar-schedule {
  position: relative;
  padding: 1rem 1.5rem 2rem 1.5rem;
}

.schedule-empty {
  text-align: center;
  padding: 4rem 2rem;
  color: #9ca3af;
}

.schedule-empty i {
  font-size: 3rem;
  margin-bottom: 1rem;
  display: block;
}

.schedule-empty p {
  margin: 0;
  font-size: 1.1rem;
  color: var(--text-muted);
}

/* ===== DAY VIEW (single day, schedule-like) ===== */
.day-view-active {
  display: block !important;
}

.day-view-container {
  max-width: 600px;
  margin: 0 auto;
  padding: 2rem 1rem;
}

.day-view-back {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.5rem 1rem;
  margin-bottom: 1.5rem;
  border: none;
  border-radius: 50px;
  background: var(--bg-color);
  border: 1px solid var(--border-color);
  color: var(--text-color);
  font-size: 0.9rem;
  font-weight: 500;
  cursor: pointer;
  transition: background 0.15s ease, transform 0.15s ease;
}

.day-view-back:hover {
  background: var(--hover-bg);
}

.day-view-back:active {
  transform: scale(0.97);
}

.day-view-back i {
  font-size: 1rem;
}

.day-view-empty {
  text-align: center;
  padding: 4rem 2rem;
  color: #9ca3af;
}

.day-view-empty i {
  font-size: 3rem;
  margin-bottom: 1rem;
  display: block;
}

.day-view-empty p {
  margin: 0 0 0.5rem;
  font-size: 1.25rem;
  color: var(--text-muted);
}

.day-view-empty small {
  color: #9ca3af;
}

.day-view-events {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.day-view-events .schedule-event {
  padding: 1rem;
  border-radius: 12px;
  background: var(--bg-secondary);
  border: 1px solid var(--border-color);
}

.day-view-events .schedule-event-icon {
  width: 48px;
  height: 48px;
  font-size: 1.25rem;
}

.day-view-events .schedule-event-title {
  font-size: 1.1rem;
}

.schedule-section {
  margin-bottom: 2rem;
}

.schedule-section-title {
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: #9ca3af;
  margin-bottom: 1rem;
  padding-bottom: 0.5rem;
  border-bottom: 1px solid var(--border-color);
}

.schedule-section-today .schedule-section-title {
  color: #3b82f6;
  border-bottom-color: #3b82f6;
}

.schedule-today-empty {
  padding: 1rem 0;
  color: var(--text-muted);
  font-size: 0.875rem;
}

.schedule-day {
  margin-bottom: 1.5rem;
}

.schedule-day.no-events {
  margin-bottom: 0.5rem;
  opacity: 0.5;
}

.schedule-day.no-events .schedule-day-header {
  border-bottom: none;
  padding-bottom: 0;
}

.schedule-day.today .schedule-day-date {
  color: #3b82f6;
}

.schedule-day.today .schedule-day-header {
  border-bottom-color: #3b82f6;
}

.grid-day.first-of-month {
  border-color: transparent;
}

.grid-day.first-of-month .grid-day-month {
  font-size: 0.6rem;
  color: var(--text-muted);
  margin-left: auto;
}

.schedule-day-header {
  display: flex;
  align-items: baseline;
  gap: 0.75rem;
  margin-bottom: 1rem;
  padding-bottom: 0.5rem;
  border-bottom: 1px solid var(--border-color);
}

.schedule-day-date {
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--text-color);
  line-height: 1;
}

.schedule-day-weekday {
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.schedule-day-relative {
  font-size: 0.8rem;
  color: #9ca3af;
  margin-left: auto;
}

.schedule-events {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.schedule-event {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 1rem 1.25rem;
  background: var(--bg-color);
  border: 1px solid var(--border-color);
  border-radius: 12px;
  contain: layout style;
}

.schedule-event-icon {
  width: 40px;
  height: 40px;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.schedule-event-icon i {
  font-size: 1.1rem;
  color: #fff;
}

.schedule-event-icon--img {
  border-radius: 50%;
  overflow: hidden;
  background: rgba(0, 0, 0, 0.1);
}

.schedule-event-icon--img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.schedule-event-content {
  flex: 1;
  min-width: 0;
}

.schedule-event-title {
  font-weight: 600;
  color: var(--text-color);
  margin-bottom: 0.125rem;
}

.schedule-event-subtitle {
  font-size: 0.8rem;
  color: var(--text-muted);
}

.schedule-event-type {
  font-size: 0.7rem;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  padding: 0.25rem 0.5rem;
  border-radius: 4px;
  background: var(--bg-secondary);
  color: var(--text-muted);
}

.schedule-event-type.release { background: #eef2ff; color: #4f46e5; }
.schedule-event-type.milestone { background: #fef3c7; color: #d97706; }
.schedule-event-type.artist { background: #f3e8ff; color: #7c3aed; }

/* Month indicator in day for context */
.schedule-day-month {
  font-size: 0.7rem;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

/* ===== DAY VIEW (Scroll-snap single column) ===== */
.calendar-day-view {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  overflow-y: auto;
  scroll-snap-type: y mandatory;
  padding: calc(50vh - 300px) 1rem;
  gap: 2rem;
  scrollbar-width: thin;
  scrollbar-color: var(--border-color) transparent;
  cursor: grab;
}

.calendar-day-view:active {
  cursor: grabbing;
}

.calendar-day-view.is-dragging {
  scroll-snap-type: none;
}

.calendar-day-view::-webkit-scrollbar {
  width: 8px;
}

.calendar-day-view::-webkit-scrollbar-track {
  background: transparent;
}

.calendar-day-view::-webkit-scrollbar-thumb {
  background: var(--border-color);
  border-radius: 4px;
}

.day-card {
  scroll-snap-align: center;
  width: 100%;
  max-width: 500px;
  background: var(--bg-color);
  border-radius: var(--radius-lg);
  padding: 2rem;
  border: 2px solid transparent;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08);
  transition: transform 0.2s ease, opacity 0.2s ease, border-color 0.2s ease;
  opacity: 0.3;
  transform: scale(0.92);
}

.day-card.is-snapped {
  opacity: 1;
  transform: scale(1);
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.12);
  border: 2px solid var(--text-color);
}

.day-card.today.is-snapped {
  border-color: var(--highlight);
}

.day-card-header {
  text-align: center;
  margin-bottom: 2rem;
  padding-bottom: 1.5rem;
  border-bottom: 1px solid var(--border-color);
}

.day-card-weekday {
  display: block;
  font-size: var(--text-base);
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin-bottom: 0.5rem;
}

.day-card-date {
  display: block;
  font-size: 5rem;
  font-weight: 700;
  line-height: 1;
  color: var(--text-color);
  margin-bottom: 0.5rem;
}

.day-card-month {
  display: block;
  font-size: var(--text-base);
  color: var(--text-muted);
}

.day-card-events {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.day-card-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 3rem;
  color: var(--text-muted);
  text-align: center;
}

.day-card-empty i {
  font-size: 3rem;
  margin-bottom: 1rem;
  opacity: 0.4;
}

.day-card-empty span {
  font-size: var(--text-md);
}

.day-event {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
  padding: 1rem;
  background: var(--bg-secondary);
  border-radius: var(--radius-md);
}

.day-event-icon {
  width: 44px;
  height: 44px;
  min-width: 44px;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: white;
  font-size: 1.25rem;
}

.day-event-icon--img {
  border-radius: 50%;
  overflow: hidden;
  background: rgba(0, 0, 0, 0.1);
}

.day-event-icon--img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.day-event-content {
  flex: 1;
  min-width: 0;
  padding-top: 0.25rem;
}

.day-event-title {
  font-weight: 600;
  font-size: var(--text-md);
  color: var(--text-color);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  margin-bottom: 0.25rem;
}

.day-event-subtitle {
  font-size: var(--text-sm);
  color: var(--text-muted);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Dark mode */
[data-theme="dark"] .day-card {
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.3);
}

[data-theme="dark"] .day-card.is-snapped {
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.5);
}

/* Day view responsive */
@media (max-width: 576px) {
  .calendar-day-view {
    padding: calc(40vh - 200px) 0.75rem;
  }

  .day-card {
    max-width: 100%;
    padding: 1.5rem;
  }

  .day-card-date {
    font-size: 4rem;
  }

  .day-event {
    padding: 0.75rem;
  }

  .day-event-icon {
    width: 40px;
    height: 40px;
    min-width: 40px;
  }
}

/* ===== GRID VIEW ===== */
.calendar-grid {
  display: grid;
  gap: 0.5rem;
}

/* Zoom levels (month uses zoom-quarter, week uses zoom-month CSS class) */
.calendar-grid.zoom-month { grid-template-columns: repeat(7, 1fr); }
.calendar-grid.zoom-quarter { grid-template-columns: repeat(14, 1fr); }

/* Responsive adjustments */
@media (max-width: 1200px) {
  .calendar-grid.zoom-quarter { grid-template-columns: repeat(10, 1fr); }
}

@media (max-width: 992px) {
  .calendar-grid.zoom-quarter { grid-template-columns: repeat(7, 1fr); }
}

@media (max-width: 900px) {
  .calendar-grid.zoom-month { grid-template-columns: repeat(4, 1fr); }
}

@media (max-width: 576px) {
  .calendar-grid.zoom-month { grid-template-columns: repeat(3, 1fr); }
  .calendar-grid.zoom-quarter { grid-template-columns: repeat(5, 1fr); }
}

/* Month header (week view only) */
.grid-month-header {
  grid-column: 1 / -1;
  padding: var(--spacing-lg) var(--spacing-sm);
  margin-top: var(--spacing-lg);
}

.grid-month-header:first-child {
  margin-top: 0;
}

.grid-month-header span {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

/* Hide month headers in week view (zoom-month) */
.calendar-grid.zoom-month .grid-month-header {
  display: none;
}

/* Day block - 4:5 aspect ratio */
.grid-day {
  position: relative;
  background: var(--bg-color);
  border: 2px solid transparent;
  border-radius: 12px;
  overflow: hidden;
  cursor: pointer;
  transition: border-color 0.15s ease, background-color 0.15s ease;
  contain: layout style;
}

.grid-day::before {
  content: '';
  display: block;
  padding-top: 125%; /* 4:5 ratio */
}

.grid-day-inner {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  padding: 0.5rem;
  display: flex;
  flex-direction: column;
}

.grid-day.today {
  border-color: #3b82f6;
  background: rgba(59, 130, 246, 0.08);
  box-shadow: inset 0 0 0 2px rgba(59, 130, 246, 0.25);
}
.grid-day.has-events { background: #fafbff; }
.grid-day.today.has-events { background: rgba(59, 130, 246, 0.1); }
.grid-day.other-month { opacity: 0.3; }
.grid-day.selected { border-color: #111827; background: #f0f9ff; }

/* Day header */
.grid-day-header {
  display: flex;
  align-items: baseline;
  gap: 0.25rem;
  margin-bottom: 0.25rem;
  flex-shrink: 0;
}

.grid-day-number {
  font-weight: 700;
  color: var(--text-color);
  line-height: 1;
}

.grid-day.today .grid-day-number {
  color: #3b82f6;
  font-weight: 800;
}

.grid-day.today .grid-day-weekday {
  color: #3b82f6;
}

.grid-day-weekday {
  font-weight: 500;
  color: #9ca3af;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.grid-day-month {
  font-size: 0.6rem;
  color: #9ca3af;
  margin-left: auto;
}

/* Zoom-specific day sizes */
.zoom-day .grid-day-number { font-size: 1.5rem; }
.zoom-day .grid-day-weekday { font-size: 0.75rem; }
.zoom-day .grid-day { border-radius: 12px; }
.zoom-day .grid-day-inner { padding: 0.75rem; }

.zoom-week .grid-day-number { font-size: 1.25rem; }
.zoom-week .grid-day-weekday { font-size: 0.65rem; }

.zoom-month .grid-day-number { font-size: 1rem; }
.zoom-month .grid-day-weekday { font-size: 0.6rem; }

.zoom-quarter .grid-day-number { font-size: 0.75rem; }
.zoom-quarter .grid-day-weekday { display: none; }
.zoom-quarter .grid-day { border-radius: 6px; }
.zoom-quarter .grid-day-inner { padding: 0.25rem; }

.zoom-year .grid-day-number { font-size: 0.6rem; }
.zoom-year .grid-day-weekday { display: none; }
.zoom-year .grid-day { border-radius: 4px; }
.zoom-year .grid-day-inner { padding: 0.2rem; }
.zoom-year .grid-day-header { margin-bottom: 0.125rem; }

/* Events inside day */
.grid-day-events {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  overflow: hidden;
}

.grid-event {
  display: flex;
  align-items: center;
  gap: 0.375rem;
  padding: 0.25rem 0.375rem;
  border-radius: 4px;
  font-size: 0.7rem;
  background: var(--bg-secondary);
}

.grid-event-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  flex-shrink: 0;
}

.grid-event-text {
  flex: 1;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  font-weight: 500;
  color: var(--text-color);
}

.grid-event-more {
  font-size: 0.65rem;
  color: var(--text-muted);
  font-weight: 500;
}

/* Compact event display for smaller zooms */
.zoom-quarter .grid-event,
.zoom-year .grid-event {
  padding: 0.125rem;
  gap: 0.125rem;
}

.zoom-quarter .grid-event-dot,
.zoom-year .grid-event-dot {
  width: 4px;
  height: 4px;
}

.zoom-quarter .grid-event-text,
.zoom-year .grid-event-text {
  display: none;
}

.zoom-year .grid-day-events {
  flex-direction: row;
  flex-wrap: wrap;
  gap: 2px;
}

/* Event count badge for tiny views */
.grid-event-count {
  display: none;
  width: 100%;
  text-align: center;
  font-size: 0.6rem;
  font-weight: 600;
  color: var(--text-muted);
}

.zoom-year .grid-event-count { display: block; }
.zoom-year .grid-event { display: none; }

/* Month divider line in grid (subtle) */
.grid-month-divider {
  grid-column: 1 / -1;
  height: 1px;
  background: var(--border-color);
  margin: 0.5rem 0;
}

/* Calendar dark mode */
[data-theme="dark"] .calendar-month-indicator {
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
}

[data-theme="dark"] .grid-day.today {
  border-color: #60a5fa;
  background: rgba(96, 165, 250, 0.15);
  box-shadow: inset 0 0 0 2px rgba(96, 165, 250, 0.3);
}
[data-theme="dark"] .grid-day.today .grid-day-number {
  color: #60a5fa;
}
[data-theme="dark"] .grid-day.today .grid-day-weekday {
  color: #60a5fa;
}
[data-theme="dark"] .grid-day.today.has-events { background: rgba(96, 165, 250, 0.15); }
[data-theme="dark"] .grid-day.has-events { background: #111; }
[data-theme="dark"] .grid-day.selected { border-color: #fff; background: #1a1a2e; }
[data-theme="dark"] .grid-event { background: rgba(255, 255, 255, 0.05); }

[data-theme="dark"] .floating-btn:hover { background: rgba(255,255,255,0.1); }
[data-theme="dark"] .floating-btn.active { background: var(--text-color); color: var(--bg-secondary); }


[data-theme="dark"] .day-view-events .schedule-event {
  background: var(--bg-secondary);
  border-color: var(--border-color);
}

/* ============================================
   SKELETON LOADING
   Shimmer effect for loading states
   ============================================ */

@keyframes shimmer {
  0% { background-position: 200% 0; }
  100% { background-position: -100% 0; }
}

.skeleton {
  background: linear-gradient(
    90deg,
    var(--bg-secondary) 0%,
    var(--border-color) 50%,
    var(--bg-secondary) 100%
  );
  background-size: 200% 100%;
  animation: shimmer 2.5s linear infinite;
  border-radius: 4px;
}

.skeleton-text {
  height: 0.875rem;
  width: 60%;
  margin-bottom: 0.25rem;
}

.skeleton-text-sm {
  height: 0.625rem;
  width: 40%;
}

.skeleton-circle {
  border-radius: 50%;
}

/* Toolbar skeleton - same direction as main shimmer */
.skeleton-toolbar .skeleton {
  background: linear-gradient(
    90deg,
    rgba(30, 30, 30, 0.4) 0%,
    rgba(60, 60, 60, 0.3) 50%,
    rgba(30, 30, 30, 0.4) 100%
  );
  background-size: 200% 100%;
  animation: shimmer 2.5s linear infinite;
}

/* Calendar skeleton states */
.grid-day.is-loading .grid-day-events {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.grid-event-skeleton {
  height: 1.25rem;
  border-radius: 4px;
  background: linear-gradient(
    90deg,
    var(--bg-secondary) 0%,
    var(--border-color) 50%,
    var(--bg-secondary) 100%
  );
  background-size: 200% 100%;
  animation: shimmer 2.5s linear infinite;
  width: 70%;
}

/* Smaller skeletons for zoomed out views */
.zoom-quarter .grid-event-skeleton,
.zoom-year .grid-event-skeleton {
  height: 0.5rem;
  width: 100%;
}

/* Hide skeleton when loaded */
.calendar-grid.is-loaded .grid-event-skeleton,
.calendar-grid.is-loaded .grid-day.is-loading {
  display: none;
}

.calendar-grid.is-loaded .grid-day.is-loading {
  display: block;
}

.calendar-grid.is-loaded .grid-day .grid-event-skeleton {
  display: none;
}

[data-theme="dark"] .skeleton,
[data-theme="dark"] .grid-event-skeleton {
  background: linear-gradient(
    90deg,
    #1a1a1a 0%,
    #2a2a2a 50%,
    #1a1a1a 100%
  );
  background-size: 200% 100%;
}

/* ============================================
   SIDEBAR DETAIL PANEL
   Master-detail pattern for artist/item details
   ============================================ */

.sidebar-detail-panel {
  position: relative;
  animation: sidebarDetailFadeIn var(--duration-normal) var(--ease-out);
}

@keyframes sidebarDetailFadeIn {
  from {
    opacity: 0;
    transform: translateY(8px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.sidebar-detail-close {
  position: absolute;
  top: 0.75rem;
  right: 0.75rem;
  width: 32px;
  height: 32px;
  border: none;
  background: var(--bg-secondary);
  border-radius: 50%;
  color: var(--text-muted);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background-color var(--duration-fast) var(--ease-out),
              color var(--duration-fast) var(--ease-out);
  z-index: 10;
}

.sidebar-detail-close:hover {
  background: var(--border-color);
  color: var(--text-color);
}

.sidebar-detail-header {
  display: flex;
  justify-content: center;
  padding: 1.5rem 1.5rem 1rem;
}

.sidebar-detail-image {
  width: 120px;
  height: 120px;
  border-radius: 50%;
  object-fit: cover;
}

.sidebar-detail-placeholder {
  width: 120px;
  height: 120px;
  border-radius: 50%;
  background: var(--bg-secondary);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-muted);
  font-size: 3rem;
}

/* Square variant for products */
.sidebar-detail-image-square {
  width: 140px;
  height: 140px;
  border-radius: var(--radius-md);
}

.sidebar-detail-placeholder-square {
  width: 140px;
  height: 140px;
  border-radius: var(--radius-md);
}

.sidebar-detail-body {
  padding: 0 1.5rem 1.5rem;
  text-align: center;
}

.sidebar-detail-name {
  font-size: var(--text-xl);
  font-weight: 600;
  color: var(--text-color);
  margin: 0 0 0.25rem;
}

.sidebar-detail-company {
  font-size: var(--text-sm);
  color: var(--text-muted);
  margin: 0 0 0.75rem;
}

.sidebar-detail-status {
  font-size: var(--text-xs);
  display: inline-block;
}

.sidebar-detail-badges {
  display: flex;
  gap: 0.5rem;
  justify-content: center;
  margin-bottom: 1.25rem;
}

.sidebar-detail-type {
  font-size: var(--text-xs);
}

.sidebar-detail-stats {
  display: flex;
  justify-content: center;
  gap: 2rem;
  margin-bottom: 1.5rem;
  padding: 1rem 0;
  border-top: 1px solid var(--border-color);
  border-bottom: 1px solid var(--border-color);
}

.sidebar-detail-stat {
  text-align: center;
}

.sidebar-detail-stat-value {
  display: block;
  font-size: var(--text-xl);
  font-weight: 600;
  color: var(--text-color);
  line-height: 1.2;
}

.sidebar-detail-stat-label {
  display: block;
  font-size: var(--text-xs);
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.sidebar-detail-section {
  text-align: left;
  margin-bottom: 1.5rem;
}

.sidebar-detail-section h6 {
  font-size: var(--text-xs);
  font-weight: 600;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-bottom: 0.5rem;
}

.sidebar-detail-section p {
  font-size: var(--text-sm);
  color: var(--text-color);
  line-height: var(--leading-relaxed);
  margin: 0;
}

.sidebar-detail-actions {
  display: flex;
  gap: 0.5rem;
  justify-content: center;
  flex-wrap: wrap;
}

.sidebar-detail-actions .btn {
  flex: 1;
  min-width: 100px;
}

/* Loading state */
.sidebar-detail-loading {
  padding: 1.5rem;
}

/* Error state */
.sidebar-detail-error {
  text-align: center;
  padding: 3rem 1.5rem;
  color: var(--text-muted);
}

.sidebar-detail-error i {
  font-size: 2.5rem;
  color: #dc3545;
  margin-bottom: 1rem;
  display: block;
}

.sidebar-detail-error p {
  margin-bottom: 1rem;
}

/* Selected state for list rows and grid cards */
.clickable-row.is-selected {
  background-color: rgba(0, 123, 255, 0.08);
}

.grid-card.is-selected .grid-card-image {
  box-shadow: inset 0 0 0 2px var(--highlight);
}

/* Dark mode adjustments */
[data-theme="dark"] .sidebar-detail-close {
  background: rgba(255, 255, 255, 0.1);
}

[data-theme="dark"] .sidebar-detail-close:hover {
  background: rgba(255, 255, 255, 0.15);
}

/* ============================================
   PREVIEW PANEL
   Live site preview in right sidebar
   ============================================ */

.preview-panel {
  display: flex;
  flex-direction: column;
  height: 100%;
  background: var(--bg-color);
}

.preview-panel-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.75rem 1rem;
  border-bottom: 1px solid var(--border-color);
  flex-shrink: 0;
}

.preview-panel-title {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--text-color);
  margin: 0;
  display: flex;
  align-items: center;
}

.preview-panel-title i {
  color: var(--text-muted);
}

.preview-panel-controls {
  display: flex;
  gap: 0.25rem;
}

.preview-device-btn {
  width: 32px;
  height: 32px;
  border: none;
  background: transparent;
  color: var(--text-muted);
  border-radius: var(--radius-sm);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all var(--duration-fast) var(--ease-out);
  text-decoration: none;
}

.preview-device-btn:hover {
  background: var(--bg-secondary);
  color: var(--text-color);
}

.preview-device-btn.active {
  background: var(--highlight);
  color: white;
}

.preview-panel-frame {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #1a1a1a;
  overflow: hidden;
  padding: 1rem;
  min-height: 0;
}

.preview-iframe {
  border: none;
  border-radius: var(--radius-md);
  background: #000;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.3);
  transition: all var(--duration-normal) var(--ease-out);
}

/* Mobile device preview */
.preview-device-mobile .preview-iframe {
  width: 280px;
  height: 100%;
  max-height: 560px;
  border: 1px solid #fff;
}

/* Desktop preview - scaled down */
.preview-device-desktop .preview-iframe {
  width: 100%;
  height: 100%;
  transform-origin: top center;
}

.preview-placeholder {
  text-align: center;
  color: rgba(255, 255, 255, 0.5);
  padding: 2rem;
}

.preview-placeholder i {
  font-size: 3rem;
  display: block;
  margin-bottom: 1rem;
  opacity: 0.3;
}

.preview-placeholder p {
  font-size: var(--text-sm);
  margin: 0;
}

.preview-panel-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.5rem 1rem;
  border-top: 1px solid var(--border-color);
  background: var(--bg-secondary);
  flex-shrink: 0;
}

.preview-url-display {
  font-size: var(--text-xs);
  color: var(--text-muted);
  font-family: var(--font-mono);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.preview-refresh-btn {
  width: 28px;
  height: 28px;
  border: none;
  background: transparent;
  color: var(--text-muted);
  border-radius: var(--radius-sm);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all var(--duration-fast) var(--ease-out);
  flex-shrink: 0;
}

.preview-refresh-btn:hover:not(:disabled) {
  background: var(--bg-color);
  color: var(--text-color);
}

.preview-refresh-btn:disabled {
  opacity: 0.3;
  cursor: not-allowed;
}

/* When preview panel is active, adjust right sidebar layout */
.right-sidebar-content:has(.preview-panel) {
  height: calc(100% - 60px);
  overflow: hidden;
}

/* ============================================
   SIDEBAR PREVIEW PANEL
   Full-bleed live preview for products
   ============================================ */

.sidebar-preview-panel {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  overflow: hidden;
  border-radius: var(--radius-lg);
}

.sidebar-preview-iframe-container {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  overflow: hidden;
  border-radius: 0;
  /* No transition by default - collapse to sidebar is instant */
}


/* Smooth expand from mobile to desktop within expanded view */
.sidebar-preview-iframe-container.is-expanding {
  transition:
    width 0.3s cubic-bezier(0.4, 0, 0.2, 1),
    height 0.3s cubic-bezier(0.4, 0, 0.2, 1),
    border-radius 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.sidebar-preview-iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: none;
  border-radius: var(--radius-lg);
  background: #000;
  transform: translateZ(0);
  contain: strict;
  will-change: contents;
  -webkit-font-smoothing: subpixel-antialiased;
  image-rendering: -webkit-optimize-contrast;
}

/* Click overlay to block iframe interaction - allows drag-to-scroll */
.sidebar-preview-click-overlay {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 10;
  cursor: grab;
  background: transparent;
  border-radius: var(--radius-lg);
  /* Capture all pointer events to block iframe interaction */
  pointer-events: auto;
}

/* When editor is open, remove overlay so iframe receives touch/scroll events */
.visual-editor-active .sidebar-preview-click-overlay {
  pointer-events: none;
}

/* Hide overlay when preview is expanded */
.right-sidebar-wrapper.is-expanded .sidebar-preview-click-overlay {
  display: none;
}

/* In collapsed sidebar, iframe captures scroll but container handles taps */
.sidebar-preview-iframe-container {
  cursor: pointer;
}

.sidebar-preview-placeholder {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  background: #000;
  color: rgba(255, 255, 255, 0.4);
  padding: 2rem;
}

.sidebar-preview-placeholder i {
  font-size: 3rem;
  display: block;
  margin-bottom: 1rem;
  opacity: 0.3;
}

.sidebar-preview-placeholder p {
  font-size: var(--text-base);
  margin: 0 0 0.25rem;
  color: rgba(255, 255, 255, 0.6);
}

.sidebar-preview-placeholder span {
  font-size: var(--text-xs);
  color: rgba(255, 255, 255, 0.4);
}

/* Floating toolbar at bottom */
.sidebar-preview-toolbar {
  position: absolute;
  bottom: 1rem;
  left: 50%;
  transform: translateX(-50%);
  display: none; /* Hidden until editor opens */
  align-items: center;
  gap: 0.5rem;
  padding: 0.5rem;
  background: rgba(0, 0, 0, 0.8);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-radius: 2rem;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3);
  z-index: 10;
}

/* Spacing for edit button */
.sidebar-preview-edit {
  margin-left: 0.25rem;
  border-left: 1px solid rgba(255, 255, 255, 0.15);
  padding-left: 0.5rem;
}

.sidebar-preview-btn {
  width: 36px;
  height: 36px;
  border: none;
  background: transparent;
  color: rgba(255, 255, 255, 0.7);
  border-radius: 50%;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all var(--duration-fast) var(--ease-out);
  text-decoration: none;
  font-size: 1rem;
}

.sidebar-preview-btn:hover {
  background: rgba(255, 255, 255, 0.15);
  color: white;
}

.sidebar-preview-btn.active {
  background: var(--highlight);
  color: white;
}

.sidebar-preview-btn.sidebar-preview-edit {
  background: rgba(255, 255, 255, 0.1);
  color: rgba(255, 255, 255, 0.5);
}

.sidebar-preview-btn.sidebar-preview-edit:hover {
  background: rgba(255, 255, 255, 0.15);
  color: rgba(255, 255, 255, 0.7);
}

.sidebar-preview-btn.sidebar-preview-edit.is-active {
  background: var(--highlight);
  color: var(--bg-color);
}

.sidebar-preview-btn.sidebar-preview-edit.is-active:hover {
  background: var(--highlight);
  filter: brightness(1.1);
  color: var(--bg-color);
}

.sidebar-preview-btn.sidebar-preview-edit i {
  font-size: 0.75rem;
  color: inherit;
}

/* Viewport toggle (Desktop/Mobile) - hidden by default, shown when expanded */
.sidebar-preview-viewport-toggle {
  display: none;
  align-items: center;
  gap: 0.5rem;
}

/* Show toolbar + viewport toggle only when editor is open */
.visual-editor-active .sidebar-preview-toolbar {
  display: flex !important;
}

.is-expanded.visual-editor-active .sidebar-preview-viewport-toggle {
  display: flex;
  animation: viewportToggleFadeIn 0.25s ease forwards;
}

@keyframes viewportToggleFadeIn {
  from {
    opacity: 0;
    transform: scale(0.8);
  }
  to {
    opacity: 1;
    transform: scale(1);
  }
}

/* Viewport buttons match existing toolbar button style */
.sidebar-preview-viewport-btn {
  width: 36px;
  height: 36px;
  border: none;
  background: transparent;
  color: rgba(255, 255, 255, 0.7);
  border-radius: 50%;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all var(--duration-fast) var(--ease-out);
  font-size: 1rem;
  flex-shrink: 0;
}

.sidebar-preview-viewport-btn:hover {
  background: rgba(255, 255, 255, 0.15);
  color: white;
}

.sidebar-preview-viewport-btn.is-active {
  background: rgba(255, 255, 255, 0.2);
  color: white;
}

.sidebar-preview-interact-btn {
  height: 32px;
  border: none;
  background: transparent;
  color: rgba(255, 255, 255, 0.5);
  border-radius: 16px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
  transition: all var(--duration-fast) var(--ease-out);
  font-size: 0.6875rem;
  font-weight: 500;
  letter-spacing: 0.02em;
  flex-shrink: 0;
  margin-left: 2px;
  border-left: 1px solid rgba(255, 255, 255, 0.1);
  padding: 0 10px 0 8px;
  white-space: nowrap;
}

/* Toolbar — floating at bottom of preview */
.sidebar-preview-toolbar {
  position: absolute !important;
  bottom: 16px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 20;
  background: rgba(0, 0, 0, 0.6);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-radius: 20px;
  padding: 4px;
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.3);
  border: 1px solid rgba(255, 255, 255, 0.08);
}

/* Floating edit/preview toggle — always visible */
.sidebar-preview-edit-fab {
  position: absolute !important;
  bottom: 16px;
  right: 16px;
  z-index: 20;
  display: flex !important;
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.3);
  background: rgba(0, 0, 0, 0.6) !important;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);

  width: 36px;
  height: 36px;
  border: none;
  background: transparent;
  color: rgba(255, 255, 255, 0.5);
  border-radius: 50%;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all var(--duration-fast) var(--ease-out);
  font-size: 1rem;
  flex-shrink: 0;
  margin-left: 4px;
}

.sidebar-preview-interact-btn:hover {
  background: rgba(255, 255, 255, 0.1);
  color: rgba(255, 255, 255, 0.8);
}

.sidebar-preview-interact-btn.is-active {
  background: rgba(72, 219, 251, 0.2);
  color: #48dbfb;
}

/* Viewport toast notification */
.sidebar-viewport-toast {
  position: absolute;
  top: 16px;
  left: 50%;
  transform: translateX(-50%) translateY(-10px);
  padding: 10px 24px;
  background: rgba(0, 0, 0, 0.85);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-radius: 9999px;
  color: white;
  font-size: var(--text-sm);
  font-weight: 500;
  z-index: 10000;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.2s ease, transform 0.2s ease;
}

/* Gradient border for toast */
.sidebar-viewport-toast::before {
  content: '';
  position: absolute;
  inset: -2px;
  border-radius: 9999px;
  background: conic-gradient(
    from var(--toast-glow-angle, 0deg),
    #48dbfb,
    #4ade80,
    #48dbfb,
    #54a0ff,
    #ff9ff3,
    #54a0ff,
    #48dbfb
  );
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  padding: 2px;
  z-index: -1;
  animation: toastGlowRotate 3s linear infinite;
}

@property --toast-glow-angle {
  syntax: '<angle>';
  initial-value: 0deg;
  inherits: false;
}

@keyframes toastGlowRotate {
  from { --toast-glow-angle: 0deg; }
  to { --toast-glow-angle: 360deg; }
}

.sidebar-viewport-toast.is-visible {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}

/* Only show toast when preview is expanded */
body:not(.preview-expanded) .sidebar-viewport-toast {
  display: none;
}

/* Toast position is set dynamically via JS — no CSS overrides needed */

/* Mobile phone frame - container shrinks to centered phone shape */
.sidebar-preview-iframe-container.is-mobile-view {
  width: 390px;
  height: min(calc(100% - 60px), 844px);
  border-radius: 12px;
  margin: auto;
  background: transparent !important;
  overflow: hidden;
  transition:
    width 0.4s cubic-bezier(0.4, 0, 0.2, 1),
    height 0.4s cubic-bezier(0.4, 0, 0.2, 1),
    border-radius 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

/* Wrapper background transition — intentional fade between mobile ↔ desktop */
.right-sidebar-wrapper.is-expanded {
  transition: background 0.8s ease;
}

/* Mobile view panel background - always match body (override #000) */
.right-sidebar-wrapper.is-expanded.is-mobile-view {
  background: var(--bg-secondary) !important;
  transition: background 0.8s ease;
}

/* Grid overlay is rendered inside the iframe - see gooey-frontend-next/src/app/globals.css */

/* Make intermediate layers transparent in mobile view */
.right-sidebar-wrapper.is-expanded.is-mobile-view .right-sidebar,
.right-sidebar-wrapper.is-expanded.is-mobile-view .right-sidebar-content,
.right-sidebar-wrapper.is-expanded.is-mobile-view .sidebar-preview-panel {
  background: transparent !important;
}


/* Iframe fills container and transitions border-radius */
.sidebar-preview-iframe {
  /* Expanding: ease-out - fast start, slow end */
  transition: border-radius 0.3s cubic-bezier(0, 0, 0.2, 1);
}

.sidebar-preview-iframe-container.is-mobile-view .sidebar-preview-iframe {
  border-radius: 12px;
  /* Shrinking: standard ease-out */
  transition: border-radius 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}


/* Loading overlay for iframe - prevents black flash */
.sidebar-preview-loading-overlay {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: #000;
  border-radius: var(--radius-lg);
  overflow: hidden;
  z-index: 10;
  transition: opacity 0.3s ease;
}

.sidebar-preview-loading-overlay.fade-out {
  opacity: 0;
  pointer-events: none;
}

/* Transition overlay for soft updates - instant show, smooth hide */
.sidebar-preview-transition-overlay {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: #000;
  border-radius: var(--radius-lg);
  overflow: hidden;
  z-index: 10;
  opacity: 0;
  pointer-events: none;
}

.sidebar-preview-transition-overlay.visible {
  opacity: 1;
}

.sidebar-preview-transition-overlay.fade-out {
  opacity: 0;
  transition: opacity 0.2s ease;
}

/* Partial loading overlay - subtle indicator while full data loads */
.sidebar-preview-partial-overlay {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  pointer-events: none;
  z-index: 5;
  border-radius: var(--radius-lg);
  overflow: hidden;
}

.sidebar-preview-partial-overlay.fade-out {
  opacity: 0;
  transition: opacity 0.3s ease;
}

.partial-loading-indicator {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  overflow: hidden;
}

.partial-loading-shimmer {
  width: 100%;
  height: 100%;
  background: linear-gradient(
    90deg,
    transparent 0%,
    rgba(255, 255, 255, 0.4) 50%,
    transparent 100%
  );
  animation: partial-shimmer 1s ease-in-out infinite;
}

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

/* Release view skeleton - matches actual frontend layout */
.sidebar-preview-skeleton {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  display: flex;
  flex-direction: column;
  background: #000;
  padding: 0;
  overflow: hidden;
  border-radius: var(--radius-lg);
}

/* Navigation icon (top left corner) */
.skeleton-nav {
  position: absolute;
  top: 0;
  left: 0;
  padding: 1rem;
  z-index: 2;
}

.skeleton-nav-icon {
  width: 36px;
  height: 36px;
  border-radius: 50%;
}

/* Expanded skeleton - align nav with share button (px-8 py-8 = 2rem) */
.is-expanded .skeleton-nav {
  padding: 2rem;
}

.is-expanded .skeleton-nav-icon {
  width: 40px;
  height: 40px;
}

.skeleton-hero {
  position: relative;
  width: 100%;
  height: 45%;
  min-height: 200px;
  background: linear-gradient(180deg, rgba(40,40,40,0.8) 0%, rgba(0,0,0,1) 100%);
}

.skeleton-hero-gradient {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    90deg,
    transparent 0%,
    rgba(255, 255, 255, 0.02) 50%,
    transparent 100%
  );
  background-size: 200% 100%;
  animation: skeletonShimmer 2.5s linear infinite;
}

.skeleton-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  padding: 0 1rem;
  margin-top: -3rem;
  position: relative;
  z-index: 1;
}

.skeleton-header-text {
  flex: 1;
  padding-right: 1rem;
}

.skeleton-title {
  width: 70%;
  height: 1.5rem;
  border-radius: 4px;
  margin-bottom: 0.5rem;
}

.skeleton-artist {
  width: 50%;
  height: 1rem;
  border-radius: 4px;
  margin-bottom: 0.5rem;
}

.skeleton-info {
  width: 40%;
  height: 0.75rem;
  border-radius: 4px;
}

.skeleton-artwork {
  width: 72px;
  height: 72px;
  border-radius: 8px;
  flex-shrink: 0;
}

.skeleton-tags {
  display: flex;
  gap: 0.5rem;
  padding: 1rem;
}

.skeleton-tag {
  width: 60px;
  height: 24px;
  border-radius: 12px;
}

.skeleton-tracks {
  padding: 0 1rem;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.skeleton-track {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.5rem 0;
}

.skeleton-track-num {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  flex-shrink: 0;
}

.skeleton-track-title {
  flex: 1;
  height: 1rem;
  border-radius: 4px;
}

.skeleton-track-duration {
  width: 32px;
  height: 0.75rem;
  border-radius: 4px;
  flex-shrink: 0;
}

/* Skeleton component blocks (below tracks) */
.skeleton-components {
  padding: 0 16px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-top: 24px;
}

.skeleton-component-block {
  width: 100%;
  height: 80px;
  border-radius: 8px;
}

.skeleton-component-line {
  width: 100%;
  height: 14px;
  border-radius: 4px;
}

.skeleton-component-line--short {
  width: 60%;
}

/* Skeleton shimmer animation - synchronized sweep */
@keyframes skeletonShimmer {
  0% {
    background-position: 200% 0;
  }
  100% {
    background-position: -100% 0;
  }
}

.sidebar-preview-skeleton .skeleton {
  background: linear-gradient(
    90deg,
    rgba(255, 255, 255, 0.05) 0%,
    rgba(255, 255, 255, 0.08) 50%,
    rgba(255, 255, 255, 0.05) 100%
  );
  background-size: 200% 100%;
  animation: skeletonShimmer 2.5s linear infinite;
}

/* Skeleton in expanded mode - centered content area like actual release view */
.is-expanded .sidebar-preview-skeleton {
  /* Override absolute fill - use flexbox centering instead */
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  padding-top: 3rem;
}

/* Inner wrapper to constrain content width */
.is-expanded .sidebar-preview-skeleton > * {
  width: 100%;
  max-width: 420px;
}

.is-expanded .skeleton-hero {
  /* Fixed height instead of percentage */
  height: 280px;
  min-height: 0;
  border-radius: var(--radius-lg) var(--radius-lg) 0 0;
}

.is-expanded .skeleton-header {
  margin-top: -3rem;
  padding: 0 1rem;
}

.is-expanded .skeleton-artwork {
  width: 72px;
  height: 72px;
}

.is-expanded .skeleton-tags {
  padding: 0.75rem 1rem;
}

.is-expanded .skeleton-tracks {
  padding: 0 1rem;
}

/* ==========================================================================
   Artist Skeleton - matches artist page layout
   ========================================================================== */

.sidebar-preview-skeleton--artist {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  display: flex;
  flex-direction: column;
  background: #000;
  padding: 0;
  overflow: hidden;
  border-radius: var(--radius-lg);
}

.skeleton-artist-hero {
  min-height: 40vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-end;
  padding: 0 1rem 2rem;
  background: linear-gradient(180deg, rgba(40,40,40,0.6) 0%, rgba(0,0,0,1) 100%);
}

.skeleton-artist-avatar {
  width: 140px;
  height: 140px;
  border-radius: 50%;
  margin-bottom: 1.25rem;
  border: 3px solid rgba(255, 255, 255, 0.15);
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.5);
}

.skeleton-artist-name {
  width: 160px;
  height: 1.75rem;
  border-radius: 4px;
}

.skeleton-artist-bio {
  padding: 2rem 1rem;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.skeleton-bio-line {
  height: 0.875rem;
  width: 100%;
  border-radius: 4px;
}

.skeleton-bio-line--short {
  width: 70%;
}

.skeleton-artist-releases {
  padding: 1rem;
  flex: 1;
}

.skeleton-section-title {
  width: 80px;
  height: 1rem;
  border-radius: 4px;
  margin-bottom: 1rem;
}

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

.skeleton-release-card {
  aspect-ratio: 4 / 5;
  border-radius: 8px;
}

/* Artist skeleton in expanded mode — match release skeleton layout */
.is-expanded .sidebar-preview-skeleton--artist {
  align-items: center;
  justify-content: flex-start;
  padding-top: 3rem;
}

.is-expanded .sidebar-preview-skeleton--artist > * {
  width: 100%;
  max-width: 420px;
}

.is-expanded .skeleton-artist-hero {
  border-radius: var(--radius-lg) var(--radius-lg) 0 0;
}

.is-expanded .skeleton-artist-avatar {
  width: 180px;
  height: 180px;
}

.is-expanded .skeleton-artist-name {
  width: 200px;
  height: 2.25rem;
}

/* Expanded desktop preview - sidebar takes over main content */
/* Expanded preview base styles - no animation by default */
.right-sidebar-wrapper.is-expanded {
  position: fixed;
  top: var(--panel-inset);
  right: var(--panel-inset);
  bottom: var(--panel-inset);
  left: calc(var(--sidebar-collapsed) + var(--panel-inset) + var(--panel-inset));
  width: auto;
  z-index: 200;
  /* Black background to hide page beneath during resize */
  background: #000;
  border-radius: var(--radius-lg);
}

/* Only animate when first expanding (class added by JS) */
.right-sidebar-wrapper.is-expanded.is-animating {
  animation: expandPreview 0.18s cubic-bezier(0.25, 0.1, 0.25, 1) forwards;
}

@keyframes expandPreview {
  from {
    left: calc(100vw - var(--panel-inset) - var(--right-sidebar-width));
    bottom: 2rem;
  }
  to {
    left: calc(var(--sidebar-collapsed) + var(--panel-inset) + var(--panel-inset));
    bottom: var(--panel-inset);
  }
}

/* Collapsed sidebar: different left position, only animate when first expanding */
@media (max-width: 1600px) {
  .right-sidebar-wrapper.is-expanded {
    left: calc(var(--sidebar-collapsed) + var(--panel-inset) + var(--panel-inset));
  }

  .right-sidebar-wrapper.is-expanded.is-animating {
    animation: expandPreviewCollapsed 0.18s cubic-bezier(0.25, 0.1, 0.25, 1) forwards;
  }

  @keyframes expandPreviewCollapsed {
    from {
      left: calc(100vw - var(--panel-inset) - var(--right-sidebar-width));
      bottom: 2rem;
    }
    to {
      left: calc(var(--sidebar-collapsed) + var(--panel-inset) + var(--panel-inset));
      bottom: var(--panel-inset);
    }
  }
}

/* Wide screens: expanded sidebar uses 320px width */
@media (min-width: 1800px) {
  .right-sidebar-wrapper.is-expanded {
    left: calc(var(--sidebar-collapsed) + var(--panel-inset) + var(--panel-inset));
  }

  .right-sidebar-wrapper.is-expanded.is-animating {
    animation: expandPreviewWide 0.18s cubic-bezier(0.25, 0.1, 0.25, 1) forwards;
  }

  @keyframes expandPreviewWide {
    from {
      left: calc(100vw - var(--panel-inset) - var(--right-sidebar-width));
      bottom: 2rem;
    }
    to {
      left: calc(var(--sidebar-collapsed) + var(--panel-inset) + var(--panel-inset));
      bottom: var(--panel-inset);
    }
  }
}

/* Workspace mode: fade up instead of slide from right */
body[data-workspace-artist] .right-sidebar-wrapper.is-expanded.is-animating {
  animation: expandPreviewFade 0.2s ease-out forwards !important;
}

@keyframes expandPreviewFade {
  from {
    opacity: 0;
    transform: translateY(8px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.right-sidebar-wrapper.is-expanded .right-sidebar-top {
  flex: 1;
}

.right-sidebar-wrapper.is-expanded .right-sidebar-bottom {
  display: none;
}

/* Dim main content when preview is expanded */
.main-content {
  transition: opacity 0.15s cubic-bezier(0.4, 0, 0.2, 1);
}

.preview-expanded .main-content {
  opacity: 0.3;
  pointer-events: none;
  transition: opacity 0.18s cubic-bezier(0.25, 0.1, 0.25, 1);
}

.main-content {
  transition: opacity var(--duration-normal) var(--ease-out);
}

/* Adjust for right sidebar content when preview is active */
.right-sidebar-content:has(.sidebar-preview-panel) {
  position: relative;
  overflow: hidden;
  border-radius: var(--radius-lg);
}

/* Hide the header when preview is showing */
.right-sidebar:has(.sidebar-preview-panel) .right-sidebar-header {
  display: none;
}

/* Make the content fill the sidebar when preview is active */
.right-sidebar:has(.sidebar-preview-panel) {
  padding: 0;
}

.right-sidebar:has(.sidebar-preview-panel) .right-sidebar-content {
  flex: 1;
  position: relative;
  min-height: 0;
}

[data-theme="dark"] .sidebar-detail-placeholder {
  background: rgba(255, 255, 255, 0.1);
}

[data-theme="dark"] .clickable-row.is-selected {
  background-color: rgba(255, 255, 255, 0.05);
}

/* grid-card.is-selected uses box-shadow which works in both themes */

/* ============================================
   MUSIC PAGE
   ============================================ */

.music-upload-area {
  background: var(--bg-color);
  border: 2px dashed var(--border-color);
  border-radius: var(--radius-lg);
  padding: 2.5rem;
  text-align: center;
  margin-bottom: 1.5rem;
  transition: border-color 0.2s ease, background-color 0.2s ease;
}

.music-upload-area:hover,
.music-upload-area.dragover {
  border-color: var(--highlight);
  background: rgba(59, 130, 246, 0.03);
}

.music-upload-area .upload-content i {
  font-size: 2.5rem;
  color: var(--text-muted);
  margin-bottom: 0.75rem;
  display: block;
}

.music-upload-area .upload-content p {
  margin: 0 0 0.25rem;
  color: var(--text-color);
}

.music-upload-area .upload-content a {
  color: var(--highlight);
  text-decoration: none;
}

.music-upload-area .upload-content a:hover {
  text-decoration: underline;
}

.music-upload-area .upload-content small {
  color: var(--text-muted);
  font-size: 0.8rem;
}

.music-upload-area .upload-progress {
  text-align: left;
}

.music-upload-area .progress-info {
  display: flex;
  justify-content: space-between;
  margin-bottom: 0.5rem;
  font-size: 0.875rem;
}

.music-upload-area .progress-filename {
  color: var(--text-color);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 80%;
}

.music-upload-area .progress-percent {
  color: var(--highlight);
  font-weight: 500;
}

.music-upload-area .progress-bar-container {
  height: 6px;
  background: var(--border-color);
  border-radius: 3px;
  overflow: hidden;
}

.music-upload-area .progress-bar-fill {
  height: 100%;
  background: var(--highlight);
  border-radius: 3px;
  transition: width 0.15s ease;
}

.music-upload-area .progress-bar-fill.is-processing {
  background: linear-gradient(
    90deg,
    var(--highlight) 0%,
    rgba(59, 130, 246, 0.6) 50%,
    var(--highlight) 100%
  );
  background-size: 200% 100%;
  animation: processingPulse 1.5s ease-in-out infinite;
}

@keyframes processingPulse {
  0% { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

/* Music list */
.music-list {
  background: var(--bg-color);
  border-radius: var(--radius-lg);
  overflow: hidden;
}

.music-table {
  margin: 0;
}

.music-table th {
  font-size: 0.7rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--text-muted);
  border-bottom: 1px solid var(--border-color);
  padding: var(--spacing-lg) var(--spacing-lg);
  padding-top: var(--spacing-xl);
  background: transparent;
}

.music-table th.col-drag {
  width: 32px;
  padding-left: var(--spacing-lg);
  padding-right: 0;
}

.music-table th.col-play {
  padding-left: var(--spacing-sm);
}

.music-table th.col-duration {
  padding-left: var(--spacing-xl);
}

.music-table th.col-added {
  padding-left: var(--spacing-xl);
  padding-right: var(--spacing-xl);
}

.music-table th.col-actions {
  padding-right: var(--spacing-lg);
}

.music-table .sortable-header {
  cursor: pointer;
  user-select: none;
  transition: color var(--duration-fast) var(--ease-out);
  white-space: nowrap;
}

.music-table .sortable-header:hover {
  color: var(--text-color);
}

.music-table .sortable-header.is-sorted {
  color: var(--highlight);
}

.music-table .sortable-header .sort-icon {
  font-size: 0.6rem;
  opacity: 0.5;
  margin-left: auto;
  float: right;
  margin-top: 2px;
}

.music-table .sortable-header:hover .sort-icon,
.music-table .sortable-header.is-sorted .sort-icon {
  opacity: 1;
}

.music-table td {
  padding: var(--spacing-lg) var(--spacing-lg);
  vertical-align: middle;
  border-bottom: 1px solid var(--border-color);
}

.music-table tbody tr:last-child td {
  border-bottom: none;
}

.music-table .col-drag {
  width: 32px;
  padding-left: var(--spacing-lg);
  padding-right: 0;
}

.music-table .drag-handle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  color: var(--text-muted);
  cursor: grab;
  opacity: 0;
  transition: opacity var(--duration-fast) var(--ease-out);
}

.music-table tr:hover .drag-handle {
  opacity: 1;
}

.music-table .drag-handle:hover {
  color: var(--text-color);
}

.music-table .drag-handle:active {
  cursor: grabbing;
}

.music-table .col-play {
  width: 50px;
  text-align: center;
  padding-left: var(--spacing-sm);
}

.music-table .col-title {
  min-width: 150px;
  max-width: 250px;
}

.music-table .col-artist {
  min-width: 120px;
  max-width: 180px;
}

.music-table .col-album {
  min-width: 120px;
  max-width: 180px;
  color: var(--text-muted);
}

.music-table .col-duration {
  width: 140px;
  padding-left: var(--spacing-xl);
  color: var(--text-muted);
  font-variant-numeric: tabular-nums;
}

.music-table .col-analysis {
  min-width: 200px;
}

.track-analysis-stats {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 11px;
  color: var(--text-muted);
  font-variant-numeric: tabular-nums;
}

.track-stat {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  white-space: nowrap;
}

.track-stat-bpm {
  font-weight: 600;
  color: var(--text-secondary);
  min-width: 32px;
}

.track-stat-bpm::after {
  content: 'bpm';
  font-weight: 400;
  font-size: 9px;
  color: var(--text-muted);
  margin-left: 1px;
}

.track-stat-key {
  font-weight: 500;
  color: var(--text-secondary);
  min-width: 24px;
}

.track-stat-energy {
  display: inline-flex;
  align-items: center;
  gap: 3px;
}

.track-stat-tags {
  font-size: 10px;
  color: var(--text-muted);
  opacity: 0.7;
}

.track-analysis-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 11px;
  color: var(--text-muted);
  font-variant-numeric: tabular-nums;
}

.track-analysis-pending {
  opacity: 0.3;
}

.analysis-energy-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  flex-shrink: 0;
}

.music-table .col-added {
  width: 140px;
  padding-left: var(--spacing-xl);
  padding-right: var(--spacing-lg);
  color: var(--text-muted);
}

.music-table .col-actions {
  width: 50px;
  text-align: center;
  padding-right: var(--spacing-lg);
}

.music-table .btn-play {
  position: relative;
  width: 36px;
  height: 36px;
  border: none;
  background: transparent;
  border-radius: 50%;
  color: var(--text-color);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: background-color 0.15s ease, transform 0.1s ease;
  padding: 0;
}

.music-table .btn-play .progress-ring {
  position: absolute;
  top: 0;
  left: 0;
  width: 36px;
  height: 36px;
  transform: rotate(-90deg);
  pointer-events: none;
}

.music-table .btn-play .progress-ring-bg {
  stroke: var(--border-color);
}

.music-table .btn-play .progress-ring-fill {
  stroke: var(--highlight);
  transition: stroke-dashoffset 0.1s linear;
}

.music-table .btn-play .play-icon,
.music-table .btn-play .pause-icon {
  position: relative;
  z-index: 1;
  font-size: 1rem;
}

.music-table .btn-play .pause-icon {
  display: none;
}

.music-table .btn-play.is-playing .play-icon {
  display: none;
}

.music-table .btn-play.is-playing .pause-icon {
  display: block;
}

.music-table .btn-play:hover {
  background: var(--highlight);
  color: #fff;
}

.music-table .btn-play:hover .progress-ring-fill {
  stroke: rgba(255, 255, 255, 0.8);
}

.music-table .btn-play:active {
  transform: scale(0.95);
}

.music-table .track-row {
  cursor: pointer;
}

.music-table .track-row:hover {
  background: rgba(0, 0, 0, 0.02);
}

.music-table .track-row.is-current {
  background: rgba(59, 130, 246, 0.05);
}

.music-table .track-row.is-current:hover {
  background: rgba(59, 130, 246, 0.08);
}

.music-table .track-row.no-audio {
  cursor: default;
  opacity: 0.5;
}

.music-table .track-row.no-audio:hover {
  background: transparent;
}

.music-table .no-audio-icon {
  width: 28px;
  height: 28px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--text-muted);
  font-size: 14px;
}

.music-table .btn-delete {
  width: 28px;
  height: 28px;
  border: none;
  background: transparent;
  color: var(--text-muted);
  cursor: pointer;
  border-radius: 4px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity 0.15s ease, color 0.15s ease, background-color 0.15s ease;
}

.music-table tr:hover .btn-delete {
  opacity: 1;
}

.music-table .btn-delete:hover {
  color: #ef4444;
  background: rgba(239, 68, 68, 0.1);
}

.music-table .track-title,
.music-table .track-artist,
.music-table .track-album {
  display: block;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.music-table .track-title {
  font-weight: 500;
  color: var(--text-color);
}

.music-table .track-artist {
  color: var(--text-muted);
}

/* Empty state */
.music-empty {
  padding: 4rem 2rem;
  text-align: center;
}

.music-empty i {
  font-size: 3rem;
  color: var(--text-muted);
  opacity: 0.5;
  margin-bottom: 1rem;
  display: block;
}

.music-empty p {
  margin: 0 0 0.25rem;
  color: var(--text-color);
  font-weight: 500;
}

.music-empty small {
  color: var(--text-muted);
}

/* Dark mode */
[data-theme="dark"] .music-upload-area {
  border-color: rgba(255, 255, 255, 0.1);
}

[data-theme="dark"] .music-upload-area:hover,
[data-theme="dark"] .music-upload-area.dragover {
  border-color: var(--highlight);
  background: rgba(59, 130, 246, 0.05);
}

[data-theme="dark"] .music-table .btn-play {
  background: transparent;
}

[data-theme="dark"] .music-table .track-row:hover {
  background: rgba(255, 255, 255, 0.03);
}

[data-theme="dark"] .music-table .track-row.is-current {
  background: rgba(59, 130, 246, 0.1);
}

[data-theme="dark"] .music-table .track-row.is-current:hover {
  background: rgba(59, 130, 246, 0.15);
}

/* ============================================
   MUSIC ALBUM FOLDERS
   ============================================ */

.music-library {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-md);
}

.music-album {
  background: var(--surface-color);
  border-radius: var(--radius-lg);
  overflow: hidden;
  border: 1px solid var(--border-color);
}

.music-album-header {
  display: flex;
  align-items: center;
  gap: var(--spacing-lg);
  padding: var(--spacing-lg);
  cursor: pointer;
  transition: background var(--duration-fast) var(--ease-out);
}

.music-album-header:hover {
  background: rgba(0, 0, 0, 0.02);
}

[data-theme="dark"] .music-album-header:hover {
  background: rgba(255, 255, 255, 0.03);
}

.music-album-artwork {
  width: 56px;
  height: 56px;
  border-radius: var(--radius-md);
  overflow: hidden;
  flex-shrink: 0;
  background: var(--border-color);
}

.music-album-artwork img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.music-album-placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, var(--border-color), var(--surface-color));
  color: var(--text-muted);
  font-size: 1.5rem;
}

.music-album-info {
  flex: 1;
  min-width: 0;
}

.music-album-name {
  display: block;
  font-weight: 600;
  color: var(--text-color);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.music-album-meta {
  display: block;
  font-size: 0.85rem;
  color: var(--text-muted);
  margin-top: 2px;
}

.music-album-actions {
  display: flex;
  align-items: center;
  opacity: 0;
  transition: opacity 0.15s ease;
}

.music-album-header:hover .music-album-actions {
  opacity: 1;
}

.btn-album-delete {
  width: 32px;
  height: 32px;
  border: none;
  background: transparent;
  color: var(--text-muted);
  cursor: pointer;
  border-radius: 6px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: color 0.15s ease, background-color 0.15s ease;
}

.btn-album-delete:hover {
  color: var(--danger);
  background: rgba(239, 68, 68, 0.1);
}

.music-album-toggle {
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-muted);
  transition: transform var(--duration-fast) var(--ease-out);
}

.music-album.is-expanded .music-album-toggle {
  transform: rotate(180deg);
}

.music-album-tracks {
  border-top: 1px solid var(--border-color);
}

.music-album-tracks .music-table {
  margin: 0;
}

.music-album-tracks .music-table td {
  padding: var(--spacing-md) var(--spacing-lg);
}

.music-album-tracks .col-num {
  width: 40px;
  text-align: center;
  padding-left: var(--spacing-lg);
}

.music-album-tracks .track-num {
  color: var(--text-muted);
  font-size: 0.85rem;
  font-variant-numeric: tabular-nums;
}

.music-album-tracks .col-play {
  width: 50px;
  padding-left: 0;
}

.music-album-tracks .col-title {
  width: auto;
}

.music-album-tracks .col-duration {
  width: 80px;
  text-align: right;
  padding-right: var(--spacing-md);
}

.music-album-tracks .col-actions {
  width: 50px;
  text-align: center;
  padding-right: var(--spacing-lg);
}

.track-artist-inline {
  display: block;
  font-size: 0.85rem;
  color: var(--text-muted);
  margin-top: 2px;
}

/* Loose tracks styling */
.music-album-loose .music-album-placeholder {
  background: linear-gradient(135deg, #6366f1, #8b5cf6);
  color: white;
}

/* ============================================
   TRACK ITEM SELECTION
   Visual feedback for keyboard delete
   ============================================ */

.track-item {
  cursor: pointer;
  outline: none;
  transition: background var(--duration-fast) var(--ease-out),
              box-shadow var(--duration-fast) var(--ease-out);
}

.track-item.is-selected {
  background: rgba(59, 130, 246, 0.08);
  box-shadow: inset 0 0 0 2px var(--highlight);
  border-radius: var(--radius-sm);
}

.track-item:focus-visible {
  box-shadow: inset 0 0 0 2px var(--highlight);
}

/* Track row selection (music table) */
.track-row.is-selected {
  background: rgba(59, 130, 246, 0.08) !important;
  box-shadow: inset 0 0 0 2px var(--highlight);
}

/* ============================================
   MEDIA PAGE - TOP BAR ACTIONS
   Filter toggles + Search
   ============================================ */

.media-page-actions {
  display: flex;
  align-items: center;
  gap: var(--spacing-md);
}

.media-filter-toggles {
  display: flex;
  gap: 4px;
  background: var(--bg-secondary);
  border-radius: var(--radius-full);
  padding: 3px;
}

.media-filter-toggle {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px;
  border: none;
  background: transparent;
  border-radius: var(--radius-full);
  font-size: 0.85rem;
  color: var(--text-muted);
  cursor: pointer;
  transition: all var(--duration-fast) var(--ease-out);
}

.media-filter-toggle:hover {
  color: var(--text-primary);
}

.media-filter-toggle.is-active {
  background: var(--bg-primary);
  color: var(--text-primary);
  box-shadow: var(--shadow-sm);
}

.media-filter-toggle i {
  font-size: 1rem;
}

.media-filter-toggle .filter-count {
  font-size: 0.75rem;
  padding: 1px 6px;
  background: var(--bg-tertiary);
  border-radius: var(--radius-full);
  color: var(--text-muted);
}

.media-filter-toggle.is-active .filter-count {
  background: var(--highlight);
  color: white;
}

.media-search {
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
  background: var(--bg-secondary);
  border-radius: var(--radius-full);
  padding: 6px 12px;
  min-width: 160px;
}

.media-search i {
  color: var(--text-muted);
  font-size: 0.85rem;
}

.media-search input {
  border: none;
  background: transparent;
  outline: none;
  font-size: 0.85rem;
  color: var(--text-primary);
  width: 100%;
}

.media-search input::placeholder {
  color: var(--text-muted);
}

/* ============================================
   MEDIA PAGE - SECTIONS
   ============================================ */

.media-section {
  padding: 0;
}

.media-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: var(--spacing-md);
  padding: var(--spacing-md);
}

.media-item {
  cursor: pointer;
  transition: transform var(--duration-fast) var(--ease-out);
}

.media-item:hover {
  transform: translateY(-2px);
}

.media-item-inner {
  position: relative;
  aspect-ratio: 1;
  border-radius: var(--radius-md);
  overflow: hidden;
  background: var(--bg-secondary);
}

.media-item-inner img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.media-item-video .media-item-inner {
  aspect-ratio: 16/9;
}

.media-item-placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  color: var(--text-muted);
  font-size: 2rem;
}

.media-item-video-overlay {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(0, 0, 0, 0.3);
  opacity: 0;
  transition: opacity var(--duration-fast);
}

.media-item-video-overlay i {
  font-size: 2.5rem;
  color: white;
}

.media-item:hover .media-item-video-overlay {
  opacity: 1;
}

.media-item-info {
  padding: var(--spacing-sm) 0;
}

.media-item-title {
  display: block;
  font-size: 0.85rem;
  font-weight: 500;
  color: var(--text-primary);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.media-item-meta {
  display: block;
  font-size: 0.8rem;
  color: var(--text-muted);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.media-empty-grid {
  grid-column: 1 / -1;
  text-align: center;
  padding: var(--spacing-xxl);
  color: var(--text-muted);
}

.media-empty-grid i {
  font-size: 3rem;
  opacity: 0.5;
  margin-bottom: var(--spacing-md);
  display: block;
}

.media-empty-grid p {
  margin: 0;
}

/* Dark mode */
[data-theme="dark"] .media-filter-toggles {
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.08);
}

[data-theme="dark"] .media-filter-toggle {
  color: rgba(255, 255, 255, 0.4);
}

[data-theme="dark"] .media-filter-toggle:hover {
  color: rgba(255, 255, 255, 0.7);
}

[data-theme="dark"] .media-filter-toggle.is-active {
  background: rgba(255, 255, 255, 0.1);
  color: rgba(255, 255, 255, 0.9);
}

[data-theme="dark"] .media-filter-toggle .filter-count {
  background: rgba(255, 255, 255, 0.06);
  color: rgba(255, 255, 255, 0.35);
}

[data-theme="dark"] .media-filter-toggle.is-active .filter-count {
  background: #48dbfb;
  color: #000;
}

[data-theme="dark"] .media-search {
  background: var(--bg-tertiary);
}

.track-row.is-selected td:first-child {
  border-radius: var(--radius-sm) 0 0 var(--radius-sm);
}

.track-row.is-selected td:last-child {
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
}

[data-theme="dark"] .track-row.is-selected {
  background: rgba(59, 130, 246, 0.15) !important;
}

[data-theme="dark"] .track-item.is-selected {
  background: rgba(59, 130, 246, 0.15);
}

/* ============================================
   TRACK TRASH DROP ZONE
   Appears at bottom during drag
   ============================================ */

.track-trash-zone {
  position: fixed;
  bottom: -80px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--spacing-sm);
  padding: var(--spacing-md) var(--spacing-xl);
  background: var(--bg-color);
  border: 2px dashed var(--border-color);
  border-radius: var(--radius-lg);
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.15);
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--text-muted);
  z-index: 9999;
  transition: bottom var(--duration-normal) var(--ease-out),
              border-color var(--duration-fast) var(--ease-out),
              background var(--duration-fast) var(--ease-out),
              color var(--duration-fast) var(--ease-out);
  pointer-events: none;
}

.track-trash-zone i {
  font-size: var(--text-lg);
}

.track-trash-zone.is-visible {
  bottom: 24px;
  pointer-events: auto;
}

.track-trash-zone.is-over {
  border-color: #dc3545;
  background: rgba(220, 53, 69, 0.1);
  color: #dc3545;
}

[data-theme="dark"] .track-trash-zone {
  background: #1a1a1a;
  border-color: #333;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.4);
}

[data-theme="dark"] .track-trash-zone.is-over {
  background: rgba(220, 53, 69, 0.2);
  border-color: #dc3545;
}

/* ============================================
   WIREFRAME PREVIEW (Create Page)
   1px outline style for new releases
   ============================================ */

.wireframe-preview {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 1rem;
  height: 100%;
  background: #0a0a0a;
  border-radius: var(--radius-lg);
  overflow: hidden;
}

.wireframe-phone {
  width: 100%;
  max-width: 280px;
  background: #000;
  border-radius: 24px;
  padding: 8px;
  box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.1);
  overflow: hidden;
  flex: 1;
  display: flex;
  flex-direction: column;
}

.wireframe-screen {
  flex: 1;
  background: #111;
  border-radius: 18px;
  overflow-y: auto;
  overflow-x: hidden;
  scrollbar-width: none;
}

.wireframe-screen::-webkit-scrollbar {
  display: none;
}

/* Hero Section */
.wireframe-hero {
  position: relative;
  padding: 2rem 1rem 1.5rem;
  background: linear-gradient(180deg, #1a1a1a 0%, #111 100%);
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
  overflow: hidden;
}

.wireframe-hero.has-image {
  background: transparent;
}

.wireframe-hero-img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0.4;
  filter: blur(4px);
}

.wireframe-hero-content {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}

.wireframe-artwork {
  width: 64px;
  height: 64px;
  border-radius: 8px;
  margin-bottom: 0.75rem;
  overflow: hidden;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.4);
}

.wireframe-artwork img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.wireframe-artwork-placeholder {
  width: 100%;
  height: 100%;
  border: 1px dashed rgba(255, 255, 255, 0.3);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.05);
}

.wireframe-title {
  font-size: 1rem;
  font-weight: 700;
  color: #fff;
  margin-bottom: 0.25rem;
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.wireframe-artist {
  font-size: 0.875rem;
  color: rgba(255, 255, 255, 0.8);
  margin-bottom: 0.25rem;
}

.wireframe-subtitle {
  font-size: 0.75rem;
  color: rgba(255, 255, 255, 0.5);
  margin-bottom: 0.5rem;
}

.wireframe-infoline {
  font-size: 0.625rem;
  color: rgba(255, 255, 255, 0.4);
  margin-bottom: 0.75rem;
}

.wireframe-tags {
  display: flex;
  gap: 0.375rem;
  flex-wrap: wrap;
  justify-content: center;
}

.wireframe-tag {
  font-size: 0.5rem;
  padding: 0.125rem 0.375rem;
  background: rgba(255, 255, 255, 0.15);
  border-radius: 9999px;
  color: rgba(255, 255, 255, 0.7);
  text-transform: uppercase;
  letter-spacing: 0.02em;
}

.wireframe-tags-placeholder {
  display: flex;
  gap: 0.375rem;
  justify-content: center;
}

.wireframe-tags-placeholder span {
  width: 32px;
  height: 12px;
  background: rgba(255, 255, 255, 0.1);
  border-radius: 9999px;
  border: 1px dashed rgba(255, 255, 255, 0.2);
}

/* Sections */
.wireframe-section {
  padding: 1rem;
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
}

.wireframe-section-placeholder {
  opacity: 0.4;
}

.wireframe-section-title {
  font-size: 0.625rem;
  font-weight: 600;
  color: rgba(255, 255, 255, 0.5);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-bottom: 0.75rem;
}

/* Tracklist */
.wireframe-tracklist {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.wireframe-track {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.375rem 0;
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
}

.wireframe-track:last-child {
  border-bottom: none;
}

.wireframe-track-num {
  width: 16px;
  font-size: 0.625rem;
  color: rgba(255, 255, 255, 0.3);
  text-align: center;
  font-style: italic;
}

.wireframe-track-play {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  border: 1px solid rgba(255, 255, 255, 0.3);
  flex-shrink: 0;
}

.wireframe-track-info {
  flex: 1;
  min-width: 0;
}

.wireframe-track-title {
  font-size: 0.6875rem;
  color: rgba(255, 255, 255, 0.8);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.wireframe-track-artist {
  font-size: 0.5rem;
  color: rgba(255, 255, 255, 0.4);
}

.wireframe-track-duration {
  font-size: 0.5rem;
  color: rgba(255, 255, 255, 0.3);
}

/* Gallery */
.wireframe-gallery {
  display: flex;
  gap: 0.5rem;
  overflow: hidden;
}

.wireframe-gallery-item {
  width: 80px;
  height: 60px;
  border: 1px dashed rgba(255, 255, 255, 0.2);
  border-radius: 6px;
  background: rgba(255, 255, 255, 0.02);
  flex-shrink: 0;
}

/* Quote */
.wireframe-quote {
  font-size: 0.75rem;
  color: rgba(255, 255, 255, 0.7);
  font-style: italic;
  line-height: 1.5;
  margin-bottom: 0.5rem;
}

.wireframe-quote-author {
  font-size: 0.5rem;
  color: rgba(255, 255, 255, 0.4);
}

.wireframe-quote-placeholder {
  height: 40px;
  border: 1px dashed rgba(255, 255, 255, 0.15);
  border-radius: 6px;
  background: rgba(255, 255, 255, 0.02);
}

/* Description */
.wireframe-description {
  font-size: 0.625rem;
  color: rgba(255, 255, 255, 0.5);
  line-height: 1.6;
}

.wireframe-description-placeholder {
  display: flex;
  flex-direction: column;
  gap: 0.375rem;
}

.wireframe-description-placeholder div {
  height: 8px;
  background: rgba(255, 255, 255, 0.08);
  border-radius: 4px;
  border: 1px dashed rgba(255, 255, 255, 0.1);
}

.wireframe-description-placeholder div:nth-child(2) {
  width: 90%;
}

.wireframe-description-placeholder div:nth-child(3) {
  width: 70%;
}

/* Credits */
.wireframe-credits {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.5rem;
}

.wireframe-credit {
  display: flex;
  flex-direction: column;
  gap: 0.125rem;
}

.wireframe-credit-label {
  font-size: 0.5rem;
  color: rgba(255, 255, 255, 0.3);
  text-transform: uppercase;
}

.wireframe-credit-value {
  font-size: 0.625rem;
  color: rgba(255, 255, 255, 0.7);
}

.wireframe-credit-placeholder {
  height: 24px;
  background: rgba(255, 255, 255, 0.05);
  border: 1px dashed rgba(255, 255, 255, 0.1);
  border-radius: 4px;
}

/* Footer */
.wireframe-footer {
  padding: 1rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.375rem;
}

.wireframe-footer-line {
  width: 60%;
  height: 6px;
  background: rgba(255, 255, 255, 0.08);
  border-radius: 3px;
}

.wireframe-footer-line.short {
  width: 40%;
  height: 4px;
}

/* Hint */
.wireframe-hint {
  margin-top: 1rem;
  font-size: 0.75rem;
  color: rgba(255, 255, 255, 0.4);
  text-align: center;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.wireframe-hint i {
  font-size: 0.875rem;
}

/* New Release badge for create preview */
.sidebar-preview-badge {
  display: flex;
  align-items: center;
  gap: 0.375rem;
  padding: 0.375rem 0.75rem;
  background: rgba(255, 255, 255, 0.1);
  border-radius: 9999px;
  font-size: 0.75rem;
  font-weight: 500;
  color: rgba(255, 255, 255, 0.7);
}

.sidebar-preview-badge i {
  font-size: 0.875rem;
}


/* ============================================
   UNSAVED CHANGES MODAL
   Minimal centered FAB-style popup
   ============================================ */

.unsaved-modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.4);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 10000;
  opacity: 0;
  transition: opacity 0.2s ease;
}

.unsaved-modal-overlay.is-visible {
  opacity: 1;
}

.unsaved-modal {
  background: var(--bg-color);
  border-radius: var(--radius-xl);
  padding: 2rem;
  text-align: center;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
  transform: scale(0.9);
  transition: transform 0.2s var(--ease-out);
  max-width: 280px;
  width: 90%;
}

.unsaved-modal-overlay.is-visible .unsaved-modal {
  transform: scale(1);
}

.unsaved-modal-icon {
  font-size: 2.5rem;
  color: var(--highlight);
  margin-bottom: 1rem;
  line-height: 1;
}

.unsaved-modal-text {
  font-size: 1rem;
  font-weight: 500;
  color: var(--text-color);
  margin: 0 0 1.5rem 0;
}

.unsaved-modal-buttons {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.unsaved-modal-btn {
  padding: 0.75rem 1.5rem;
  border: none;
  border-radius: var(--radius-md);
  font-size: 0.875rem;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.15s ease;
}

.unsaved-modal-btn-cancel {
  background: var(--bg-secondary);
  color: var(--text-color);
}

.unsaved-modal-btn-cancel:hover {
  background: var(--border-color);
}

.unsaved-modal-btn-confirm {
  background: #ef4444;
  color: white;
}

.unsaved-modal-btn-confirm:hover {
  background: #dc2626;
}


.unsaved-modal-checkbox {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  margin-bottom: 1.25rem;
  font-size: 0.8125rem;
  color: var(--text-muted);
  cursor: pointer;
}

.unsaved-modal-checkbox input[type="checkbox"] {
  width: 1rem;
  height: 1rem;
  cursor: pointer;
  accent-color: var(--highlight);
}

/* ============================================
   ARTIST PICKER MODAL
   For selecting artist when creating new release
   ============================================ */

.artist-picker-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.6);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 10000;
  opacity: 0;
  transition: opacity 0.2s ease;
}

.artist-picker-overlay.is-visible {
  opacity: 1;
}

.artist-picker-modal {
  background: var(--bg-color);
  border-radius: var(--radius-xl);
  padding: 1.5rem;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.4);
  transform: scale(0.9);
  transition: transform 0.2s var(--ease-out);
  max-width: 320px;
  width: 90%;
}

.artist-picker-overlay.is-visible .artist-picker-modal {
  transform: scale(1);
}

.artist-picker-header {
  font-size: 1rem;
  font-weight: 600;
  color: var(--text-color);
  margin-bottom: 1rem;
  text-align: center;
}

.artist-picker-list {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  max-height: 300px;
  overflow-y: auto;
}

.artist-picker-item {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.75rem;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: background 0.15s ease, border-color 0.15s ease;
}

.artist-picker-item:hover {
  background: rgba(255, 255, 255, 0.1);
  border-color: rgba(255, 255, 255, 0.2);
}

.artist-picker-item img {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  object-fit: cover;
}

.artist-picker-placeholder {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.1);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-muted);
}

.artist-picker-name {
  font-size: 0.9375rem;
  font-weight: 500;
  color: var(--text-color);
}

/* ============================================
   RELEASE PICKER MODAL
   For selecting from discography when creating new release
   ============================================ */

.release-picker-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.6);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 10100;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.2s ease;
}

.release-picker-overlay.is-visible {
  opacity: 1;
  pointer-events: auto;
}

.release-picker-modal {
  background: var(--bg-color);
  border-radius: var(--radius-xl);
  padding: 0;
  max-height: 80vh;
  max-width: 400px;
  width: 90%;
  transform: scale(0.95);
  transition: transform 0.2s ease;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

.release-picker-overlay.is-visible .release-picker-modal {
  transform: scale(1);
}

.release-picker-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1rem 1.25rem;
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

.release-picker-header span {
  font-size: 1rem;
  font-weight: 600;
  color: var(--text-color);
}

.release-picker-close {
  background: none;
  border: none;
  color: var(--text-muted);
  font-size: 1.5rem;
  line-height: 1;
  cursor: pointer;
  padding: 0;
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  transition: background 0.15s ease, color 0.15s ease;
}

.release-picker-close:hover {
  background: rgba(255, 255, 255, 0.1);
  color: var(--text-color);
}

.release-picker-list {
  display: flex;
  flex-direction: column;
  padding: 0.75rem;
  overflow-y: auto;
  max-height: 60vh;
}

.release-picker-divider {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.75rem 0.5rem;
  color: var(--text-muted);
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.release-picker-divider::after {
  content: '';
  flex: 1;
  height: 1px;
  background: rgba(255, 255, 255, 0.1);
}

.release-picker-item {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.625rem 0.75rem;
  background: transparent;
  border: 1px solid transparent;
  border-radius: var(--radius-md);
  cursor: pointer;
  text-align: left;
  transition: background 0.15s ease, border-color 0.15s ease;
}

.release-picker-item:hover {
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(255, 255, 255, 0.15);
}

.release-picker-item.release-picker-blank {
  background: rgba(var(--primary-rgb), 0.1);
  border-color: rgba(var(--primary-rgb), 0.2);
}

.release-picker-item.release-picker-blank:hover {
  background: rgba(var(--primary-rgb), 0.15);
  border-color: rgba(var(--primary-rgb), 0.3);
}

.release-picker-art {
  width: 48px;
  height: 48px;
  border-radius: var(--radius-sm);
  object-fit: cover;
  flex-shrink: 0;
}

.release-picker-placeholder {
  width: 48px;
  height: 48px;
  border-radius: var(--radius-sm);
  background: rgba(255, 255, 255, 0.08);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-muted);
  font-size: 1.25rem;
  flex-shrink: 0;
}

.release-picker-blank .release-picker-placeholder {
  background: rgba(var(--primary-rgb), 0.15);
  color: var(--primary-color);
}

.release-picker-info {
  display: flex;
  flex-direction: column;
  gap: 0.125rem;
  min-width: 0;
}

.release-picker-title {
  font-size: 0.9375rem;
  font-weight: 500;
  color: var(--text-color);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.release-picker-meta {
  font-size: 0.8125rem;
  color: var(--text-muted);
}

/* ============================================
   GENERATING RELEASE OVERLAY
   Shows progress when creating release from API
   ============================================ */

.generating-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.85);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 10200;
  opacity: 0;
  transition: opacity 0.2s ease;
}

.generating-overlay.is-visible {
  opacity: 1;
}

.generating-modal {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1.5rem;
  padding: 2rem;
  text-align: center;
}

.generating-spinner {
  width: 48px;
  height: 48px;
  border: 3px solid rgba(255, 255, 255, 0.1);
  border-top-color: var(--primary-color);
  border-radius: 50%;
  animation: generating-spin 1s linear infinite;
}

@keyframes generating-spin {
  to { transform: rotate(360deg); }
}

.generating-title {
  font-size: 1.25rem;
  font-weight: 600;
  color: var(--text-color);
  max-width: 300px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.generating-status {
  font-size: 0.9375rem;
  color: var(--text-muted);
  min-height: 1.5em;
  transition: opacity 0.15s ease;
}

/* ============================================
   UNIFIED IMPORT MODAL
   Single entry point for artist + release imports
   ============================================ */

.import-modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.6);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 10000;
  opacity: 0;
  transition: opacity 0.2s ease;
}

.import-modal-overlay.is-visible {
  opacity: 1;
}

.import-modal {
  position: relative;
  background: var(--bg-color);
  border-radius: var(--radius-xl);
  padding: 2rem;
  max-width: 420px;
  width: 90%;
  max-height: 85vh;
  overflow-y: auto;
  transform: scale(0.95);
  transition: transform 0.2s ease;
}

.import-modal-overlay.is-visible .import-modal {
  transform: scale(1);
}

.import-modal::-webkit-scrollbar { width: 6px; }
.import-modal::-webkit-scrollbar-track { background: transparent; }
.import-modal::-webkit-scrollbar-thumb { background: rgba(255, 255, 255, 0.15); border-radius: 3px; }

.import-modal-close {
  position: absolute;
  top: 1rem;
  right: 1rem;
  background: none;
  border: none;
  color: var(--text-muted);
  font-size: 1.25rem;
  cursor: pointer;
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  transition: background 0.15s ease, color 0.15s ease;
}

.import-modal-close:hover {
  background: rgba(255, 255, 255, 0.1);
  color: var(--text-color);
}

.import-modal-header {
  text-align: center;
  margin-bottom: 1.5rem;
}

.import-modal-header h2 {
  font-size: 1.25rem;
  font-weight: 600;
  color: var(--text-color);
  margin: 0 0 0.25rem;
}

.import-modal-header p {
  font-size: 0.875rem;
  color: var(--text-muted);
  margin: 0;
}

.import-modal-input-group {
  display: flex;
  gap: 0.5rem;
  margin-bottom: 0.25rem;
}

.import-modal-input-group input {
  flex: 1;
  padding: 0.75rem 1rem;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: var(--radius-md);
  color: var(--text-color);
  font-size: 0.875rem;
  outline: none;
  transition: border-color 0.15s ease, background 0.15s ease;
}

.import-modal-input-group input:focus {
  border-color: rgba(255, 255, 255, 0.3);
  background: rgba(255, 255, 255, 0.08);
}

.import-modal-input-group input::placeholder {
  color: rgba(255, 255, 255, 0.3);
}

.import-modal-input-group button {
  padding: 0 1rem;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: var(--radius-md);
  color: var(--text-color);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.125rem;
  transition: background 0.15s ease, border-color 0.15s ease;
}

.import-modal-input-group button:hover {
  background: rgba(255, 255, 255, 0.1);
  border-color: rgba(255, 255, 255, 0.2);
}

.import-modal-status {
  font-size: 0.75rem;
  min-height: 1.25em;
  padding: 0.25rem 0 0;
  color: var(--text-muted);
  transition: color 0.15s ease;
}

.import-modal-status.error { color: #ef4444; }
.import-modal-status.success { color: #22c55e; }
.import-modal-status.loading { color: rgba(255, 255, 255, 0.5); }

.import-modal-divider {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 1rem 0;
  color: var(--text-muted);
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.import-modal-divider::before,
.import-modal-divider::after {
  content: '';
  flex: 1;
  height: 1px;
  background: rgba(255, 255, 255, 0.1);
}

.import-modal-options {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.import-modal-option {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.625rem 0.75rem;
  background: transparent;
  border: 1px solid transparent;
  border-radius: var(--radius-md);
  cursor: pointer;
  text-align: left;
  width: 100%;
  color: inherit;
  text-decoration: none;
  transition: background 0.15s ease, border-color 0.15s ease;
}

.import-modal-option:hover {
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(255, 255, 255, 0.15);
}

.import-modal-option-icon {
  width: 40px;
  height: 40px;
  border-radius: var(--radius-sm);
  background: rgba(255, 255, 255, 0.08);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-muted);
  font-size: 1.125rem;
  flex-shrink: 0;
}

.import-modal-option.blank .import-modal-option-icon {
  background: rgba(var(--primary-rgb), 0.15);
  color: var(--primary-color);
}

.import-modal-option.blank {
  background: rgba(var(--primary-rgb), 0.06);
  border-color: rgba(var(--primary-rgb), 0.15);
}

.import-modal-option.blank:hover {
  background: rgba(var(--primary-rgb), 0.12);
  border-color: rgba(var(--primary-rgb), 0.25);
}

.import-modal-option-info {
  display: flex;
  flex-direction: column;
  gap: 0.125rem;
  min-width: 0;
}

.import-modal-option-title {
  font-size: 0.9375rem;
  font-weight: 500;
  color: var(--text-color);
}

.import-modal-option-meta {
  font-size: 0.8125rem;
  color: var(--text-muted);
}

.import-modal-option img {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
}

.import-modal-option .release-picker-art {
  border-radius: var(--radius-sm);
}

.import-modal-section-label {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.75rem 0 0.375rem;
  color: var(--text-muted);
  font-size: 0.6875rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.import-modal-section-label::after {
  content: '';
  flex: 1;
  height: 1px;
  background: rgba(255, 255, 255, 0.08);
}

.import-modal-discography {
  max-height: 280px;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.import-modal-discography::-webkit-scrollbar { width: 6px; }
.import-modal-discography::-webkit-scrollbar-track { background: rgba(255, 255, 255, 0.03); }
.import-modal-discography::-webkit-scrollbar-thumb { background: rgba(255, 255, 255, 0.12); border-radius: 3px; }

.import-modal-loading {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 1rem;
  color: var(--text-muted);
  font-size: 0.8125rem;
}

.import-modal-loading::before {
  content: '';
  width: 16px;
  height: 16px;
  border: 2px solid rgba(255, 255, 255, 0.1);
  border-top-color: var(--text-muted);
  border-radius: 50%;
  animation: generating-spin 0.8s linear infinite;
}

/* Import modal — progress state (replaces input area during import) */
.import-modal-progress {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1rem;
  padding: 2rem 0;
  text-align: center;
}

.import-modal-progress-spinner {
  width: 36px;
  height: 36px;
  border: 3px solid rgba(255, 255, 255, 0.1);
  border-top-color: var(--text-color);
  border-radius: 50%;
  animation: generating-spin 0.8s linear infinite;
}

.import-modal-progress-text {
  font-size: 0.875rem;
  color: var(--text-muted);
  min-height: 1.25em;
}

/* Import modal — success state */
.import-modal-success {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.25rem;
  padding: 1.5rem 0 1rem;
  text-align: center;
}

.import-modal-success-icon {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: rgba(34, 197, 94, 0.15);
  color: #22c55e;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.25rem;
  margin-bottom: 0.5rem;
}

.import-modal-success-title {
  font-size: 1.125rem;
  font-weight: 600;
  color: var(--text-color);
  max-width: 300px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.import-modal-success-meta {
  font-size: 0.8125rem;
  color: var(--text-muted);
}

/* Import modal — action buttons */
.import-modal-actions {
  display: flex;
  gap: 0.5rem;
  padding-top: 1rem;
}

.import-modal-btn {
  flex: 1;
  padding: 0.75rem 1.25rem;
  border-radius: var(--radius-md);
  font-size: 0.875rem;
  font-weight: 500;
  cursor: pointer;
  border: none;
  transition: opacity 0.15s ease, background 0.15s ease;
}

.import-modal-btn:hover { opacity: 0.9; }

.import-modal-btn-primary {
  background: var(--text-color);
  color: var(--bg-color);
}

.import-modal-btn-secondary {
  background: rgba(255, 255, 255, 0.08);
  color: var(--text-color);
  border: 1px solid rgba(255, 255, 255, 0.1);
}

.import-modal-btn-secondary:hover {
  background: rgba(255, 255, 255, 0.12);
}

/* Import modal — imported item state (checkmark, muted) */
.import-modal-option.imported {
  opacity: 0.5;
  pointer-events: none;
}

.import-modal-option.imported .import-modal-option-icon {
  background: rgba(34, 197, 94, 0.15);
  color: #22c55e;
}

.import-modal-option.importing .import-modal-option-icon {
  background: transparent;
  position: relative;
}

.import-modal-option.importing .import-modal-option-icon::after {
  content: '';
  width: 20px;
  height: 20px;
  border: 2px solid rgba(255, 255, 255, 0.1);
  border-top-color: var(--text-color);
  border-radius: 50%;
  animation: generating-spin 0.8s linear infinite;
}

.import-modal-option.importing .import-modal-option-icon i { display: none; }

/* ============================================
   DELETE CONFIRMATION MODAL
   Matches unsaved changes popup style
   ============================================ */

.delete-modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.4);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 10100;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.2s ease;
}

.delete-modal-overlay.is-visible {
  opacity: 1;
  pointer-events: auto;
}

.delete-modal {
  background: var(--bg-color);
  border-radius: var(--radius-xl);
  padding: 2rem;
  text-align: center;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
  transform: scale(0.9);
  transition: transform 0.2s var(--ease-out);
  max-width: 300px;
  width: 90%;
}

.delete-modal-overlay.is-visible .delete-modal {
  transform: scale(1);
}

.delete-modal-icon {
  font-size: 2.5rem;
  color: #ef4444;
  margin-bottom: 1rem;
  line-height: 1;
}

.delete-modal-title {
  font-size: 1rem;
  font-weight: 600;
  color: var(--text-color);
  margin: 0 0 0.5rem 0;
}

.delete-modal-text {
  font-size: 0.875rem;
  color: var(--text-muted);
  margin: 0 0 1.5rem 0;
  line-height: 1.5;
}

.delete-modal-name {
  font-weight: 600;
  color: var(--text-color);
}

.delete-modal-buttons {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.delete-modal-btn {
  padding: 0.75rem 1.5rem;
  border: none;
  border-radius: var(--radius-md);
  font-size: 0.875rem;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.15s ease;
}

.delete-modal-btn-cancel {
  background: var(--bg-secondary);
  color: var(--text-color);
}

.delete-modal-btn-cancel:hover {
  background: var(--border-color);
}

.delete-modal-btn-delete {
  background: #ef4444;
  color: white;
}

.delete-modal-btn-delete:hover {
  background: #dc2626;
}

/* ============================================
   MEDIA LIBRARY
   ============================================ */

/* Hide top bar on media page (has its own controls) */
.page-media .top-bar-search {
  display: none;
}

/* Media controls bar */
.media-controls {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 0 0 1rem;
  margin-bottom: 0.5rem;
  position: sticky;
  top: 0;
  background: var(--bg-body);
  z-index: 10;
}

.media-controls-left {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.media-controls-right {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

/* Filter pills */
.media-filter-pills {
  display: flex;
  align-items: center;
  gap: 0.25rem;
}

.media-filter-pill {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  padding: 0.5rem 0.875rem;
  background: transparent;
  border: 1px solid var(--border-color);
  border-radius: 20px;
  color: var(--text-muted);
  font-size: 0.8125rem;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.15s ease;
}

.media-filter-pill:hover {
  border-color: var(--text-muted);
  color: var(--text-color);
}

.media-filter-pill.active {
  background: var(--text-color);
  border-color: var(--text-color);
  color: var(--bg-color);
}

.media-filter-pill i {
  font-size: 0.875rem;
}

.media-filter-count {
  font-size: 0.75rem;
  opacity: 0.7;
}

/* Zoom control */
.media-zoom-control {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.25rem;
  background: var(--bg-secondary);
  border-radius: 8px;
}

.media-zoom-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border: none;
  background: transparent;
  color: var(--text-muted);
  border-radius: 6px;
  cursor: pointer;
  transition: all 0.15s ease;
}

.media-zoom-btn:hover {
  background: var(--bg-tertiary);
  color: var(--text-color);
}

.media-zoom-slider {
  width: 80px;
}

.media-zoom-slider input[type="range"] {
  width: 100%;
  height: 4px;
  -webkit-appearance: none;
  appearance: none;
  background: var(--border-color);
  border-radius: 2px;
  outline: none;
}

.media-zoom-slider input[type="range"]::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 14px;
  height: 14px;
  background: var(--text-color);
  border-radius: 50%;
  cursor: pointer;
}

.media-zoom-slider input[type="range"]::-moz-range-thumb {
  width: 14px;
  height: 14px;
  background: var(--text-color);
  border-radius: 50%;
  cursor: pointer;
  border: none;
}

/* Media grid with zoom levels */
.media-grid {
  display: grid;
  gap: 0.5rem;
  transition: gap 0.2s ease;
}

/* Zoom levels: 1 = largest, 5 = smallest */
.media-grid.zoom-1 { grid-template-columns: repeat(2, 1fr); gap: 1rem; }
.media-grid.zoom-2 { grid-template-columns: repeat(3, 1fr); gap: 0.75rem; }
.media-grid.zoom-3 { grid-template-columns: repeat(4, 1fr); gap: 0.5rem; }
.media-grid.zoom-4 { grid-template-columns: repeat(6, 1fr); gap: 0.375rem; }
.media-grid.zoom-5 { grid-template-columns: repeat(8, 1fr); gap: 0.25rem; }

@media (max-width: 1200px) {
  .media-grid.zoom-1 { grid-template-columns: repeat(2, 1fr); }
  .media-grid.zoom-2 { grid-template-columns: repeat(3, 1fr); }
  .media-grid.zoom-3 { grid-template-columns: repeat(4, 1fr); }
  .media-grid.zoom-4 { grid-template-columns: repeat(5, 1fr); }
  .media-grid.zoom-5 { grid-template-columns: repeat(6, 1fr); }
}

@media (max-width: 768px) {
  .media-grid.zoom-1 { grid-template-columns: repeat(2, 1fr); }
  .media-grid.zoom-2 { grid-template-columns: repeat(2, 1fr); }
  .media-grid.zoom-3 { grid-template-columns: repeat(3, 1fr); }
  .media-grid.zoom-4 { grid-template-columns: repeat(4, 1fr); }
  .media-grid.zoom-5 { grid-template-columns: repeat(5, 1fr); }
}

/* Media item */
.media-item {
  cursor: pointer;
  border-radius: 8px;
  overflow: hidden;
  transition: transform 0.15s ease, box-shadow 0.15s ease;
}

.media-item:hover {
  transform: scale(1.02);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

.media-item-inner {
  position: relative;
  aspect-ratio: 1;
  background: var(--bg-secondary);
  overflow: hidden;
}

.media-item-image img,
.media-item-audio img,
.media-item-video img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.media-item-placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(145deg, var(--bg-secondary), var(--bg-tertiary));
  color: var(--text-muted);
  font-size: 2rem;
}

.media-item-audio,
.media-item-video {
  position: relative;
}

.media-item-audio-overlay,
.media-item-video-overlay {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(0, 0, 0, 0.3);
  color: white;
  font-size: 1.5rem;
  opacity: 0;
  transition: opacity 0.15s ease;
}

.media-item:hover .media-item-audio-overlay,
.media-item:hover .media-item-video-overlay {
  opacity: 1;
}

.media-item-duration {
  position: absolute;
  bottom: 4px;
  right: 4px;
  padding: 2px 6px;
  background: rgba(0, 0, 0, 0.7);
  color: white;
  font-size: 0.625rem;
  border-radius: 4px;
}

/* Media item info (hidden at smaller zoom levels) */
.media-item-info {
  padding: 0.5rem;
  background: var(--bg-color);
}

.media-item-title {
  display: block;
  font-size: 0.75rem;
  font-weight: 500;
  color: var(--text-color);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.media-item-meta {
  display: block;
  font-size: 0.6875rem;
  color: var(--text-muted);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Hide info at smaller zoom levels */
.media-grid.zoom-4 .media-item-info,
.media-grid.zoom-5 .media-item-info {
  display: none;
}

.media-grid.zoom-4 .media-item,
.media-grid.zoom-5 .media-item {
  border-radius: 4px;
}

/* Media empty state */
.media-empty {
  grid-column: 1 / -1;
  padding: 4rem 2rem;
}

/* Lightbox - stays within content area, respects both sidebars */
.media-lightbox {
  position: fixed;
  top: var(--panel-inset);
  left: calc(var(--panel-inset) + var(--sidebar-collapsed) + var(--panel-gap));
  bottom: var(--panel-inset);
  right: calc(var(--panel-inset) + var(--right-sidebar-width) + var(--panel-gap));
  z-index: 1000;
  background: rgba(0, 0, 0, 0.95);
  border-radius: var(--radius-lg);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.2s ease, visibility 0.2s ease;
}

/* Mobile - full screen lightbox (no sidebars) */
@media (max-width: 899.98px) {
  .media-lightbox {
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    border-radius: 0;
  }
}

.media-lightbox.is-open {
  opacity: 1;
  visibility: visible;
}

.media-lightbox-close {
  position: absolute;
  top: 1rem;
  right: 1rem;
  width: 44px;
  height: 44px;
  border: none;
  background: rgba(255, 255, 255, 0.1);
  color: white;
  border-radius: 50%;
  cursor: pointer;
  font-size: 1.25rem;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.15s ease;
  z-index: 10;
}

.media-lightbox-close:hover {
  background: rgba(255, 255, 255, 0.2);
}

.media-lightbox-nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 44px;
  height: 44px;
  border: none;
  background: rgba(255, 255, 255, 0.1);
  color: white;
  border-radius: 50%;
  cursor: pointer;
  font-size: 1.25rem;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.15s ease;
  z-index: 10;
}

.media-lightbox-nav:hover {
  background: rgba(255, 255, 255, 0.2);
}

.media-lightbox-prev {
  left: 1rem;
}

.media-lightbox-next {
  right: 1rem;
}

.media-lightbox-content {
  max-width: 90vw;
  max-height: 80vh;
  display: flex;
  align-items: center;
  justify-content: center;
}

.media-lightbox-content img {
  max-width: 100%;
  max-height: 80vh;
  object-fit: contain;
  border-radius: 8px;
}

.media-lightbox-content video {
  max-width: 100%;
  max-height: 80vh;
  border-radius: 8px;
}

.media-lightbox-content audio {
  width: 400px;
  max-width: 90vw;
}

.media-lightbox-info {
  position: absolute;
  bottom: 2rem;
  left: 50%;
  transform: translateX(-50%);
  text-align: center;
  color: white;
}

.media-lightbox-title {
  font-size: 1rem;
  font-weight: 600;
  margin: 0 0 0.25rem;
}

.media-lightbox-meta {
  font-size: 0.875rem;
  opacity: 0.7;
  margin: 0;
}

/* Mobile adjustments */
@media (max-width: 768px) {
  .media-controls {
    flex-direction: column;
    align-items: stretch;
    gap: 0.75rem;
  }

  .media-filter-pills {
    overflow-x: auto;
    padding-bottom: 0.25rem;
    -webkit-overflow-scrolling: touch;
  }

  .media-filter-pill {
    flex-shrink: 0;
  }

  .media-controls-right {
    justify-content: flex-end;
  }

  .media-lightbox-nav {
    width: 36px;
    height: 36px;
    font-size: 1rem;
  }

  .media-lightbox-prev {
    left: 0.5rem;
  }

  .media-lightbox-next {
    right: 0.5rem;
  }
}

/* ============================================
   TRACK DETAIL PANEL
   ============================================ */

/* Hero */
.track-detail-hero {
  position: relative;
  overflow: hidden;
  background: #111;
}

.track-detail-hero-img {
  width: 100%;
  display: block;
  aspect-ratio: 1;
  object-fit: cover;
}

.track-detail-hero-fade {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 60%;
  background: linear-gradient(to bottom, transparent 0%, rgba(0,0,0,0.85) 100%);
}

[data-theme="light"] .track-detail-hero { background: #e5e5e5; }
[data-theme="light"] .track-detail-hero-fade {
  background: linear-gradient(to bottom, transparent 0%, rgba(255,255,255,0.95) 100%);
}

.track-detail-hero-info {
  position: absolute;
  bottom: 16px;
  left: 20px;
  right: 20px;
  z-index: 1;
}

.track-detail-title {
  font-size: 16px;
  font-weight: 700;
  color: #fff;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  line-height: 1.3;
}

.track-detail-artist {
  font-size: 12px;
  color: rgba(255, 255, 255, 0.6);
  margin-top: 2px;
}

[data-theme="light"] .track-detail-title { color: #111; }
[data-theme="light"] .track-detail-artist { color: rgba(0, 0, 0, 0.5); }

/* Body */
.track-detail-body {
  padding: 20px;
}

.track-detail-loading {
  color: var(--text-muted);
  font-size: 16px;
  text-align: center;
  padding: 40px 0;
}

.track-detail-loading .spin {
  display: inline-block;
  animation: spin 1s linear infinite;
}

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

/* Tags */
.td-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  margin-bottom: 16px;
}

.td-tag {
  font-size: 10px;
  padding: 3px 10px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.06);
  color: rgba(255, 255, 255, 0.5);
  font-weight: 500;
  border: 1px solid rgba(255, 255, 255, 0.06);
  text-transform: capitalize;
}

[data-theme="light"] .td-tag {
  background: rgba(0, 0, 0, 0.04);
  color: rgba(0, 0, 0, 0.5);
  border-color: rgba(0, 0, 0, 0.06);
}

/* Stats grid */
.td-stats-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--border-color);
  border-radius: 8px;
  overflow: hidden;
  margin-bottom: 20px;
}

.td-stat {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 12px 4px;
  background: var(--surface-color);
}

[data-theme="dark"] .td-stat { background: #1a1a1a; }

.td-stat-value {
  font-size: 15px;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  line-height: 1.2;
  display: flex;
  align-items: center;
  gap: 4px;
}

.td-stat-label {
  font-size: 8px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--text-muted);
  margin-top: 3px;
}

/* Confidence dot */
.td-conf-dot {
  width: 5px;
  height: 5px;
  border-radius: 50%;
  display: inline-block;
  flex-shrink: 0;
}

.td-conf-dot.td-conf-high { background: #4ade80; }
.td-conf-dot.td-conf-medium { background: #facc15; }
.td-conf-dot.td-conf-low { background: #ef4444; }

/* Sections */
.td-section {
  margin-bottom: 18px;
}

.td-section-title {
  font-size: 9px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: rgba(255, 255, 255, 0.25);
  margin-bottom: 10px;
}

[data-theme="light"] .td-section-title {
  color: rgba(0, 0, 0, 0.3);
}

/* Rows */
.td-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 4px 0;
  font-size: 12px;
}

.td-label {
  color: var(--text-muted);
  flex-shrink: 0;
  margin-right: 12px;
}

.td-value {
  text-align: right;
  font-weight: 500;
  font-variant-numeric: tabular-nums;
}

.td-conf {
  font-size: 8px;
  font-weight: 600;
  text-transform: uppercase;
  margin-left: 6px;
  padding: 1px 5px;
  border-radius: 3px;
}

.td-conf-high { color: #4ade80; background: rgba(74, 222, 128, 0.1); }
.td-conf-medium { color: #facc15; background: rgba(250, 204, 21, 0.1); }
.td-conf-low { color: #ef4444; background: rgba(239, 68, 68, 0.1); }

/* Bars */
.td-bar-outer {
  display: flex;
  align-items: center;
  gap: 8px;
  flex: 1;
  max-width: 180px;
}

.td-bar-wrap {
  flex: 1;
  height: 4px;
  background: rgba(255, 255, 255, 0.06);
  border-radius: 2px;
  overflow: hidden;
}

[data-theme="light"] .td-bar-wrap {
  background: rgba(0, 0, 0, 0.06);
}

.td-bar {
  height: 100%;
  border-radius: 2px;
  min-width: 1px;
  transition: width 0.4s ease;
}

.td-bar-val {
  font-size: 10px;
  color: var(--text-muted);
  min-width: 28px;
  text-align: right;
  font-variant-numeric: tabular-nums;
  flex-shrink: 0;
}

/* Active track highlight */
.track-row.is-detail-active {
  background: rgba(72, 219, 251, 0.06) !important;
}

/* ============================================
   ARTIST FILTER
   Simple filter - JS sets display:none on non-matching rows
   Tray always available for navigation between artists
   ============================================ */

/* ============================================
   MOBILE BOTTOM BAR
   Premium fixed navigation for < 900px
   ============================================ */

.mobile-bottom-bar {
  display: none;
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  height: calc(56px + env(safe-area-inset-bottom, 0px));
  padding-bottom: env(safe-area-inset-bottom, 0px);
  background: rgba(var(--bg-color-rgb, 18, 18, 18), 0.92);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-top: 1px solid rgba(255, 255, 255, 0.06);
  z-index: 1000;
  align-items: stretch;
  justify-content: stretch;
}

.mobile-bottom-item {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2px;
  background: none;
  border: none;
  color: var(--text-muted);
  text-decoration: none;
  font-size: 10px;
  font-family: TWKLausanne, -apple-system, sans-serif;
  font-weight: 400;
  letter-spacing: 0.02em;
  cursor: pointer;
  transition: color 0.15s ease;
  -webkit-tap-highlight-color: transparent;
  padding: 6px 0;
}

.mobile-bottom-item i {
  font-size: 20px;
  line-height: 1;
}

.mobile-bottom-item span {
  line-height: 1;
}

.mobile-bottom-item.is-active,
.mobile-bottom-item:active {
  color: var(--text-color);
}

.mobile-bottom-edit,
.mobile-bottom-desktop {
  display: none; /* Shown when canvas is active */
}

/* Mobile overlay */
.mobile-overlay {
  display: none;
  position: fixed;
  inset: 0;
  bottom: calc(56px + env(safe-area-inset-bottom, 0px));
  background: rgba(0, 0, 0, 0.5);
  z-index: 399;
  opacity: 0;
  transition: opacity 0.25s ease;
}

.mobile-overlay.is-visible {
  display: block;
  opacity: 1;
}

@media (max-width: 899.98px) {
  .mobile-bottom-bar {
    display: flex;
  }

  /* Hide old mobile UI */
  .mobile-sidebar,
  .mobile-sidebar-overlay,
  .mobile-add-wrapper,
  .top-bar-logo,
  .bottom-tab-bar,
  .radial-trigger,
  .radial-menu,
  .radial-overlay {
    display: none !important;
  }

  /* Adjust main content for bottom bar */
  .main-content-inner {
    padding-bottom: calc(56px + env(safe-area-inset-bottom, 0px) + 1rem) !important;
  }

  /* Hide desktop sidebar */
  .sidebar {
    display: none !important;
  }

  /* Main content full width */
  main.main-content {
    left: var(--panel-inset) !important;
  }

  /* Top bar full width */
  .top-bar {
    left: var(--panel-inset) !important;
  }

  /* When canvas is active, show edit/desktop/back buttons, hide nav */
  body.mobile-canvas-active .mobile-bottom-item:not(.mobile-bottom-edit):not(.mobile-bottom-desktop):not(.mobile-bottom-back) {
    display: none;
  }

  body.mobile-canvas-active .mobile-bottom-edit,
  body.mobile-canvas-active .mobile-bottom-desktop,
  body.mobile-canvas-active .mobile-bottom-back {
    display: flex;
  }

  /* Canvas takes over the screen — full width, scrollable, like viewing the live site */
  body.mobile-canvas-active .main-content {
    display: none !important;
  }

  body.mobile-canvas-active .top-bar {
    display: none !important;
  }

  body.mobile-canvas-active .right-sidebar-wrapper {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: calc(56px + env(safe-area-inset-bottom, 0px)) !important;
    width: 100% !important;
    transform: none !important;
    border-radius: 0 !important;
    background: #000;
  }

  body.mobile-canvas-active .right-sidebar-preview {
    width: 100% !important;
    height: 100% !important;
    border-radius: 0 !important;
    background: #000;
    overflow: hidden !important;
  }

  body.mobile-canvas-active .sidebar-preview-iframe {
    width: 100% !important;
    height: 100% !important;
    border-radius: 0 !important;
  }

  /* Hide preview chrome in mobile canvas */
  body.mobile-canvas-active .right-sidebar-header,
  body.mobile-canvas-active .sidebar-preview-toolbar,
  body.mobile-canvas-active .iframe-collapse-btn,
  body.mobile-canvas-active .right-sidebar-bottom {
    display: none !important;
  }

  /* Desktop overview mode — zoomed out */
  body.mobile-desktop-mode .sidebar-preview-iframe {
    transform: scale(0.55);
    transform-origin: top center;
    width: 100% !important;
    height: 180% !important;
  }

  body.mobile-desktop-mode .right-sidebar-preview {
    overflow-y: auto !important;
  }

  /* Visual editor tray on mobile — slides from right, hidden by default */
  body.mobile-canvas-active .ve-tray {
    position: fixed !important;
    top: 0 !important;
    right: 0 !important;
    bottom: calc(56px + env(safe-area-inset-bottom, 0px)) !important;
    width: 280px !important;
    z-index: 400 !important;
    border-radius: 0 !important;
    transform: translateX(100%) !important;
    transition: transform 0.25s cubic-bezier(0.4, 0, 0.2, 1) !important;
  }

  body.mobile-canvas-active .ve-tray.is-open {
    transform: translateX(0) !important;
  }
}

