/* ===== COLORPIKR STYLES ===== */
/* © 2025 VILAAN | The Best Color Picker */

/* ===== CSS VARIABLES ===== */
/* ASCII bytes PIXEL - Dark Theme (Default) */
:root {
  /* Accent Color - Orange (matching ASCII bytes PIXEL) */
  --cp-accent: #D49C6B;
  --cp-accent-hover: #C48A5A;
  --cp-accent-gradient: linear-gradient(135deg, #C48A5A 0%, #D49C6B 50%, #E5AF81 100%);
  --cp-accent-glow: 0 0 20px rgba(212, 156, 107, 0.3);
  --cp-accent-secondary: rgba(212, 156, 107, 0.3);
  
  /* Backgrounds - Dark (matching --dark-bg, --dark-surface) */
  --cp-bg-primary: #1A1A1A;
  --cp-bg-secondary: #242424;
  --cp-bg-tertiary: #2E2E2E;
  --cp-bg-gradient: #1A1A1A;
  --cp-modal-bg: transparent;
  
  /* Text - Light (matching --dark-text) */
  --cp-text-primary: #E5E5E5;
  --cp-text-secondary: #A0A0A0;
  --cp-text-tertiary: #808080;
  
  /* Input fields - IMPORTANT: light text on dark bg */
  --cp-input-bg: #2E2E2E;
  --cp-input-border: #3A3A3A;
  --cp-input-text: #FFFFFF;
  
  /* Borders (matching --dark-border) */
  --cp-border: #3A3A3A;
  --cp-border-hover: #D49C6B;
  
  /* Shadows */
  --cp-shadow: 0 8px 32px rgba(0, 0, 0, 0.5);
  --cp-shadow-sm: 0 4px 16px rgba(0, 0, 0, 0.3);
  --cp-shadow-inner: inset 0 1px 2px rgba(0, 0, 0, 0.2);
  
  /* Sizing */
  --cp-square-size: 160px;
  --cp-border-radius: 6px;
  --cp-border-radius-lg: 12px;
}

/* ASCII bytes PIXEL - Light Theme */
:root[data-theme="light"] {
  /* Backgrounds - Light (matching --light-bg, --light-surface) */
  --cp-bg-primary: #F5F5F5;
  --cp-bg-secondary: #FFFFFF;
  --cp-bg-tertiary: #EBEBEB;
  --cp-bg-gradient: #F5F5F5;
  
  /* Text - Dark (matching --light-text) */
  --cp-text-primary: #1A1A1A;
  --cp-text-secondary: #666666;
  --cp-text-tertiary: #888888;
  
  /* Input fields - dark text on light bg */
  --cp-input-bg: #FFFFFF;
  --cp-input-border: #D0D0D0;
  --cp-input-text: #1A1A1A;
  
  /* Borders (matching --light-border) */
  --cp-border: #D0D0D0;
  --cp-border-hover: #D49C6B;
  
  /* Shadows - lighter */
  --cp-shadow: 0 8px 32px rgba(0, 0, 0, 0.15);
  --cp-shadow-sm: 0 4px 16px rgba(0, 0, 0, 0.1);
  --cp-shadow-inner: inset 0 1px 2px rgba(0, 0, 0, 0.05);
}

/* DREAMY UI - VARIANT 2: Dark Blue/Slate with Orange */
:root[data-dreamy="variant2"] {
  /* Accent Color - Orange Gradient (original accent) */
  --cp-accent: #D49C6B;
  --cp-accent-hover: #E5AF81;
  --cp-accent-gradient: linear-gradient(135deg, #C8915E 0%, #D49C6B 50%, #E5AF81 100%);
  --cp-accent-glow: 0 0 30px rgba(212, 156, 107, 0.4), 0 0 60px rgba(200, 145, 94, 0.2);
  
  /* Backgrounds - Dark Blue/Slate */
  --cp-bg-primary: rgba(20, 34, 46, 0.90);
  --cp-bg-secondary: rgba(51, 70, 87, 0.92);
  --cp-bg-tertiary: rgba(99, 124, 150, 0.5);
  --cp-bg-gradient: linear-gradient(135deg, #14222E 0%, #334657 50%, #637C96 100%);
  --cp-modal-bg: linear-gradient(135deg, rgba(20, 34, 46, 0.30) 0%, rgba(51, 70, 87, 0.25) 50%, rgba(99, 124, 150, 0.15) 100%);
  
  /* Text - Soft White/Light Blue */
  --cp-text-primary: rgba(244, 248, 249, 0.98);
  --cp-text-secondary: rgba(165, 183, 198, 0.90);
  --cp-text-tertiary: rgba(165, 183, 198, 0.6);
  
  /* Borders - Soft Blue Glow */
  --cp-border: rgba(165, 183, 198, 0.15);
  --cp-border-hover: rgba(212, 156, 107, 0.5);
  
  /* Shadows - Dark Blue with Orange Glow */
  --cp-shadow: 0 20px 70px rgba(20, 34, 46, 0.5), 0 0 50px rgba(212, 156, 107, 0.15);
  --cp-shadow-sm: 0 8px 32px rgba(51, 70, 87, 0.4), 0 0 20px rgba(212, 156, 107, 0.1);
  --cp-shadow-inner: inset 0 1px 3px rgba(244, 248, 249, 0.15);
}

/* DREAMY UI - VARIANT 3: Dark Slate/Blue with Orange */
:root[data-dreamy="variant3"] {
  /* Accent Color - Orange Gradient */
  --cp-accent: #D49C6B;
  --cp-accent-hover: #E5AF81;
  --cp-accent-gradient: linear-gradient(135deg, #C8915E 0%, #D49C6B 50%, #E5AF81 100%);
  --cp-accent-glow: 0 0 30px rgba(212, 156, 107, 0.4), 0 0 60px rgba(200, 145, 94, 0.2);
  
  /* Backgrounds - Very Dark Slate/Blue */
  --cp-bg-primary: rgba(12, 26, 35, 0.92);
  --cp-bg-secondary: rgba(35, 51, 64, 0.94);
  --cp-bg-tertiary: rgba(69, 86, 99, 0.5);
  --cp-bg-gradient: linear-gradient(135deg, #0C1A23 0%, #233340 50%, #455663 100%);
  --cp-modal-bg: linear-gradient(135deg, rgba(12, 26, 35, 0.35) 0%, rgba(35, 51, 64, 0.28) 50%, rgba(69, 86, 99, 0.20) 100%);
  
  /* Text - Light Gray/White (matching screenshot) */
  --cp-text-primary: rgba(200, 210, 215, 1);
  --cp-text-secondary: rgba(140, 155, 170, 0.95);
  --cp-text-tertiary: rgba(120, 135, 150, 0.75);
  
  /* Borders - Cool Blue Glow */
  --cp-border: rgba(141, 153, 158, 0.15);
  --cp-border-hover: rgba(212, 156, 107, 0.5);
  
  /* Shadows - Deep Dark with Orange Glow */
  --cp-shadow: 0 20px 70px rgba(12, 26, 35, 0.6), 0 0 50px rgba(212, 156, 107, 0.15);
  --cp-shadow-sm: 0 8px 32px rgba(35, 51, 64, 0.45), 0 0 20px rgba(212, 156, 107, 0.1);
  --cp-shadow-inner: inset 0 1px 3px rgba(141, 153, 158, 0.12);
}

/* DREAMY UI - VARIANT 4: Navy/Purple with Warm Sunset */
:root[data-dreamy="variant4"] {
  /* Accent Color - Warm Sunset Gradient */
  --cp-accent: #ffaa5e;
  --cp-accent-hover: #ffd4a3;
  --cp-accent-gradient: linear-gradient(135deg, #d08159 0%, #ffaa5e 50%, #ffd4a3 100%);
  --cp-accent-glow: 0 0 30px rgba(255, 170, 94, 0.4), 0 0 60px rgba(208, 129, 89, 0.2);
  
  /* Backgrounds - Deep Navy/Purple */
  --cp-bg-primary: rgba(13, 43, 69, 0.90);
  --cp-bg-secondary: rgba(32, 60, 86, 0.92);
  --cp-bg-tertiary: rgba(84, 78, 104, 0.55);
  --cp-bg-gradient: linear-gradient(135deg, #0d2b45 0%, #203c56 50%, #544e68 100%);
  --cp-modal-bg: linear-gradient(135deg, rgba(13, 43, 69, 0.32) 0%, rgba(32, 60, 86, 0.26) 50%, rgba(84, 78, 104, 0.20) 100%);
  
  /* Text - Warm Light */
  --cp-text-primary: rgba(255, 236, 214, 0.98);
  --cp-text-secondary: rgba(255, 212, 163, 0.88);
  --cp-text-tertiary: rgba(141, 105, 122, 0.7);
  
  /* Borders - Warm Glow */
  --cp-border: rgba(255, 170, 94, 0.12);
  --cp-border-hover: rgba(255, 170, 94, 0.5);
  
  /* Shadows - Navy with Sunset Glow */
  --cp-shadow: 0 20px 70px rgba(13, 43, 69, 0.55), 0 0 50px rgba(255, 170, 94, 0.18);
  --cp-shadow-sm: 0 8px 32px rgba(32, 60, 86, 0.4), 0 0 20px rgba(208, 129, 89, 0.12);
  --cp-shadow-inner: inset 0 1px 3px rgba(255, 236, 214, 0.15);
}

/* DREAMY UI - VARIANT 5: Deep Burgundy/Red */
:root[data-dreamy="variant5"] {
  /* Accent Color - Coral/Pink Gradient */
  --cp-accent: #ff8274;
  --cp-accent-hover: #d53c6a;
  --cp-accent-gradient: linear-gradient(135deg, #ff8274 0%, #d53c6a 50%, #7c183c 100%);
  --cp-accent-glow: 0 0 30px rgba(255, 130, 116, 0.4), 0 0 60px rgba(213, 60, 106, 0.2);
  
  /* Backgrounds - Very Dark Burgundy */
  --cp-bg-primary: rgba(19, 2, 8, 0.95);
  --cp-bg-secondary: rgba(31, 5, 16, 0.96);
  --cp-bg-tertiary: rgba(70, 14, 43, 0.6);
  --cp-bg-gradient: linear-gradient(135deg, #130208 0%, #1f0510 50%, #31051e 100%);
  --cp-modal-bg: linear-gradient(135deg, rgba(19, 2, 8, 0.40) 0%, rgba(31, 5, 16, 0.35) 50%, rgba(49, 5, 30, 0.28) 100%);
  
  /* Text - Soft Pink/White */
  --cp-text-primary: rgba(255, 130, 116, 0.95);
  --cp-text-secondary: rgba(213, 60, 106, 0.85);
  --cp-text-tertiary: rgba(124, 24, 60, 0.7);
  
  /* Borders - Red Glow */
  --cp-border: rgba(255, 130, 116, 0.15);
  --cp-border-hover: rgba(255, 130, 116, 0.5);
  
  /* Shadows - Deep Red with Coral Glow */
  --cp-shadow: 0 20px 70px rgba(19, 2, 8, 0.7), 0 0 50px rgba(213, 60, 106, 0.2);
  --cp-shadow-sm: 0 8px 32px rgba(31, 5, 16, 0.5), 0 0 20px rgba(255, 130, 116, 0.15);
  --cp-shadow-inner: inset 0 1px 3px rgba(255, 130, 116, 0.15);
}

/* DREAMY UI - VARIANT 6: Monochrome Gray/Mauve */
:root[data-dreamy="variant6"] {
  /* Accent Color - Soft Pink/Mauve Gradient */
  --cp-accent: #d5becd;
  --cp-accent-hover: #ded6de;
  --cp-accent-gradient: linear-gradient(135deg, #c5b2bd 0%, #d5becd 50%, #ded6de 100%);
  --cp-accent-glow: 0 0 30px rgba(213, 190, 205, 0.35), 0 0 60px rgba(197, 178, 189, 0.18);
  
  /* Backgrounds - Dark Gray/Mauve */
  --cp-bg-primary: rgba(57, 44, 49, 0.92);
  --cp-bg-secondary: rgba(74, 60, 74, 0.94);
  --cp-bg-tertiary: rgba(90, 85, 90, 0.55);
  --cp-bg-gradient: linear-gradient(135deg, #392c31 0%, #4a3c4a 50%, #5a555a 100%);
  --cp-modal-bg: linear-gradient(135deg, rgba(57, 44, 49, 0.35) 0%, rgba(74, 60, 74, 0.28) 50%, rgba(90, 85, 90, 0.22) 100%);
  
  /* Text - Light Gray/Mauve */
  --cp-text-primary: rgba(230, 234, 238, 0.98);
  --cp-text-secondary: rgba(222, 214, 222, 0.88);
  --cp-text-tertiary: rgba(164, 157, 164, 0.7);
  
  /* Borders - Mauve Glow */
  --cp-border: rgba(230, 234, 238, 0.12);
  --cp-border-hover: rgba(213, 190, 205, 0.5);
  
  /* Shadows - Gray with Mauve Glow */
  --cp-shadow: 0 20px 70px rgba(57, 44, 49, 0.5), 0 0 50px rgba(197, 178, 189, 0.18);
  --cp-shadow-sm: 0 8px 32px rgba(74, 60, 74, 0.4), 0 0 20px rgba(213, 190, 205, 0.12);
  --cp-shadow-inner: inset 0 1px 3px rgba(230, 234, 238, 0.15);
}

/* ===== MODAL ===== */
.colorpikr-modal {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 10001;
  display: none;
  align-items: flex-start;
  justify-content: flex-start;
  background: transparent;
  pointer-events: auto;
  opacity: 0;
  transition: opacity 0.2s ease;
}

.colorpikr-modal[style*="display: block"] {
  display: flex !important;
  opacity: 1;
}

.colorpikr-content {
  position: absolute;
  background: var(--cp-bg-primary);
  border: 1px solid var(--cp-border);
  border-radius: var(--cp-border-radius-lg);
  padding: 16px;
  padding-top: 12px;
  box-shadow: var(--cp-shadow);
  width: 280px;
  min-width: 280px;
  overflow: visible;
  animation: slideIn 0.2s ease-out;
}

/* Mobile: center the modal */
@media (max-width: 767px) {
  .colorpikr-modal {
    align-items: center;
    justify-content: center;
  }
  .colorpikr-content {
    position: relative;
    top: auto !important;
    left: auto !important;
  }
}

.colorpikr-content.dragging {
  cursor: grabbing !important;
}

.colorpikr-draggable-area {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 20px;
  cursor: move;
  z-index: 1;
  pointer-events: auto;
  background: rgba(0, 0, 0, 0.3);
  border-radius: var(--cp-border-radius-lg) var(--cp-border-radius-lg) 0 0;
}

@keyframes slideIn {
  from {
    transform: translateY(-20px);
    opacity: 0;
  }
  to {
    transform: translateY(0);
    opacity: 1;
  }
}

@keyframes fadeInOut {
  0% {
    opacity: 0;
    transform: translateX(-50%) translateY(-4px);
  }
  20% {
    opacity: 1;
    transform: translateX(-50%) translateY(0);
  }
  80% {
    opacity: 1;
    transform: translateX(-50%) translateY(0);
  }
  100% {
    opacity: 0;
    transform: translateX(-50%) translateY(-4px);
  }
}

/* ===== TAB SYSTEM #1: Primary Tabs (Icon Mode) ===== */
.colorpikr-tabs-primary {
  display: flex;
  gap: 8px;
  margin-bottom: 12px;
}

.colorpikr-tab {
  flex: 1;
  padding: 10px;
  background: var(--cp-bg-tertiary);
  backdrop-filter: blur(10px);
  border: 1px solid var(--cp-border);
  border-radius: var(--cp-border-radius);
  cursor: pointer;
  transition: all 0.3s ease;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: var(--cp-shadow-sm), var(--cp-shadow-inner);
}

.colorpikr-tab svg {
  color: var(--cp-text-secondary);
  transition: all 0.3s ease;
  filter: drop-shadow(0 0 4px rgba(255, 255, 255, 0.1));
}

.colorpikr-tab:hover {
  background: var(--cp-bg-primary);
  border-color: var(--cp-border-hover);
  box-shadow: var(--cp-shadow-sm), var(--cp-accent-glow);
  transform: translateY(-1px);
}

.colorpikr-tab:hover svg {
  color: var(--cp-accent);
  filter: drop-shadow(0 0 8px rgba(212, 156, 107, 0.4));
}

.colorpikr-tab.active {
  background: var(--cp-bg-primary);
  border-color: var(--cp-accent);
  box-shadow: var(--cp-shadow-sm), var(--cp-accent-glow), var(--cp-shadow-inner);
}

.colorpikr-tab.active svg {
  color: var(--cp-accent);
  filter: drop-shadow(0 0 8px rgba(212, 156, 107, 0.5));
}

/* ===== CONTENT AREA ===== */
.colorpikr-content-area {
  position: relative;
  min-height: 200px;
  margin-bottom: 8px;
  height: auto;
  overflow: hidden;
}

.colorpikr-pane {
  display: none;
  height: 100%;
  overflow: visible;
}

.colorpikr-pane[data-pane="guide"] {
  overflow-y: auto;
  overflow-x: hidden;
}

.colorpikr-pane.active {
  display: block;
}

.colorpikr-tabs-content {
  flex: 1;
  overflow: visible;
}

/* ===== FIELD TAB ===== */
.colorpikr-field-toggle {
  margin-bottom: 8px;
}

.field-toggle-btn {
  width: 100%;
  padding: 6px 12px;
  background: var(--cp-bg-tertiary);
  border: 1px solid var(--cp-border);
  border-radius: var(--cp-border-radius);
  color: var(--cp-text-primary);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.5px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s;
}

.field-toggle-btn:hover {
  background: #2a2a2a;
  border-color: var(--cp-accent);
}

.colorpikr-square {
  width: 100%;
  aspect-ratio: 1.5;
  position: relative;
  border-radius: var(--cp-border-radius);
  cursor: crosshair;
  touch-action: none;
  background: linear-gradient(to bottom, transparent, black),
              linear-gradient(to right, white, transparent);
  box-shadow: var(--cp-shadow-sm);
  margin-bottom: 12px;
  transition: aspect-ratio 0.3s ease;
}

.colorpikr-cursor {
  position: absolute;
  width: 16px;
  height: 16px;
  border: 2px solid white;
  border-radius: 50%;
  pointer-events: none;
  transform: translate(-50%, -50%);
  box-shadow: 0 0 5px rgba(0, 0, 0, 0.5), inset 0 0 5px rgba(0, 0, 0, 0.5);
  transition: box-shadow 0.2s;
}

/* ===== SLIDERS ===== */
.colorpikr-slider-row {
  margin-bottom: 12px;
  width: 100%;
}

.colorpikr-slider-row:last-child {
  margin-bottom: 5px;
}

.colorpikr-slider-row label {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 12px;
  font-weight: 600;
  color: var(--cp-text-secondary);
  margin-bottom: 6px;
  width: 100%;
}

.slider-with-input {
  display: flex;
  gap: 8px;
  align-items: center;
}

.colorpikr-slider {
  flex: 1;
  height: 8px;
  border-radius: 4px;
  outline: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background: var(--cp-bg-tertiary);
  cursor: pointer;
}

.colorpikr-slider::-webkit-slider-thumb {
  -webkit-appearance: none;
  width: 18px;
  height: 18px;
  background: var(--cp-accent);
  border: 2px solid #fff;
  border-radius: 50%;
  cursor: pointer;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.4);
  transition: transform 0.2s;
}

.colorpikr-slider::-webkit-slider-thumb:hover {
  transform: scale(1.15);
  background: var(--cp-accent-hover);
}

.colorpikr-slider::-moz-range-thumb {
  width: 18px;
  height: 18px;
  background: var(--cp-accent);
  border: 2px solid #fff;
  border-radius: 50%;
  cursor: pointer;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.4);
}

/* Slider Specific Backgrounds */
.hue-slider {
  background: linear-gradient(to right,  
    #ff0000 0%, #ffff00 17%, #00ff00 33%, 
    #00ffff 50%, #0000ff 67%, #ff00ff 83%, #ff0000 100%) !important;
}

.opacity-slider {
  background: linear-gradient(to right, transparent, var(--cp-accent)),
              repeating-linear-gradient(45deg, #ccc 0, #ccc 2px, #fff 2px, #fff 4px) !important;
}

/* Dynamic slider backgrounds - will be set via JS */
#sliderSatInput {
  background: linear-gradient(to right, #808080, var(--cp-accent)) !important;
}

#sliderBrightInput {
  background: linear-gradient(to right, #000000, var(--cp-accent)) !important;
}

#sliderRedInput {
  background: linear-gradient(to right, #000000, #ff0000) !important;
}

#sliderGreenInput {
  background: linear-gradient(to right, #000000, #00ff00) !important;
}

#sliderBlueInput {
  background: linear-gradient(to right, #000000, #0000ff) !important;
}

#sliderSatInputHSL {
  background: linear-gradient(to right, #808080, var(--cp-accent)) !important;
}

#sliderLightInput {
  background: linear-gradient(to right, #000000, #ffffff) !important;
}

.slider-number {
  width: 50px;
  padding: 4px 8px;
  background: var(--cp-bg-tertiary);
  border: 1px solid var(--cp-border);
  border-radius: 6px;
  color: var(--cp-text-primary);
  font-size: 12px;
  font-weight: 600;
  text-align: center;
}

.slider-number:focus {
  outline: none;
  border-color: var(--cp-accent);
}

/* Remove number spinner */
.slider-number::-webkit-inner-spin-button,
.slider-number::-webkit-outer-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

.slider-number {
  -moz-appearance: textfield;
  appearance: textfield;
}

/* ===== GRID TAB ===== */
.colorpikr-grid-container {
  margin-bottom: 12px;
  padding: 4px;
}

.color-grid-row {
  display: flex;
  gap: 2px;
  margin-bottom: 2px;
}

.color-grid-row:last-child {
  margin-bottom: 0;
}

.color-grid-cell {
  flex: 1;
  aspect-ratio: 1;
  min-width: 0;
  cursor: pointer;
  border-radius: 2px;
  transition: transform 0.15s, box-shadow 0.15s;
}

.color-grid-cell:hover {
  transform: scale(1.15);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.4);
  z-index: 1;
}

/* ===== SLIDERS TAB ===== */
.colorpikr-sliders-container {
  padding: 4px 0;
}

.slider-set {
  display: none !important;
}

.slider-set.active {
  display: block !important;
}

/* ===== GUIDE TAB ===== */
.colorpikr-guide-header {
  display: flex;
  justify-content: center;
  align-items: center;
  margin-bottom: 12px;
  flex-shrink: 0;
}

.mode-toggle-container {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: 100%;
}

.mode-label {
  font-size: 11px;
  font-weight: 600;
  color: var(--cp-text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  cursor: pointer;
}

.mode-toggle-switch {
  position: relative;
  display: inline-block;
  width: 44px;
  height: 22px;
}

.mode-toggle-switch input {
  opacity: 0;
  width: 0;
  height: 0;
}

.toggle-slider {
  position: absolute;
  cursor: pointer;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: var(--cp-accent);
  transition: 0.3s;
  border-radius: 22px;
  border: 2px solid var(--cp-accent);
}

.toggle-slider:before {
  position: absolute;
  content: "";
  height: 14px;
  width: 14px;
  left: 2px;
  bottom: 2px;
  background-color: #1a1a1a;
  transition: 0.3s;
  border-radius: 50%;
}

input:checked + .toggle-slider:before {
  transform: translateX(22px);
}

input:focus + .toggle-slider {
  box-shadow: 0 0 1px var(--cp-accent);
}

.colorpikr-guide-container {
  overflow-x: hidden;
  overflow-y: auto;
  width: 100%;
  flex: 1;
  padding-right: 4px;
}

.colorpikr-guide-container::-webkit-scrollbar {
  width: 6px;
}

.colorpikr-guide-container::-webkit-scrollbar-track {
  background: var(--cp-bg-tertiary);
  border-radius: 3px;
}

.colorpikr-guide-container::-webkit-scrollbar-thumb {
  background: var(--cp-accent);
  border-radius: 3px;
}

.colorpikr-guide-container::-webkit-scrollbar-thumb:hover {
  background: var(--cp-accent-hover);
}

.harmony-group {
  margin-bottom: 16px;
  width: 100%;
  overflow: hidden;
}

.harmony-group:last-child {
  margin-bottom: 0;
}

.harmony-title {
  font-size: 10px;
  font-weight: 700;
  color: var(--cp-text-secondary);
  text-transform: uppercase;
  margin-bottom: 8px;
  letter-spacing: 0.5px;
}

.harmony-colors {
  display: flex;
  gap: 4px;
  flex-wrap: wrap;
  width: 100%;
  max-width: 100%;
}

.harmony-color-item {
  flex: 1;
  min-width: 0;
  position: relative;
}

.harmony-color-box {
  width: 100%;
  height: 32px;
  border-radius: var(--cp-border-radius);
  cursor: pointer;
  transition: transform 0.15s, box-shadow 0.15s;
  box-shadow: var(--cp-shadow-sm);
}

.harmony-color-box:hover {
  transform: translateY(-2px);
  box-shadow: 0 3px 10px rgba(0, 0, 0, 0.4);
}

/* Tooltip - shows on hover AND touch */
.harmony-tooltip {
  position: absolute;
  bottom: calc(100% + 4px);
  background: var(--cp-bg-primary);
  color: var(--cp-accent);
  padding: 4px 8px;
  border-radius: 4px;
  font-size: 10px;
  font-weight: 600;
  font-family: 'Courier New', monospace;
  white-space: nowrap;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.5);
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.2s;
  z-index: 10;
  max-width: 120px;
}

.harmony-tooltip.tooltip-left {
  left: 0;
  transform: none;
}

.harmony-tooltip.tooltip-center {
  left: 50%;
  transform: translateX(-50%);
}

.harmony-tooltip.tooltip-right {
  right: 0;
  transform: none;
}

.harmony-color-item:hover .harmony-tooltip,
.harmony-color-item.touch-active .harmony-tooltip {
  opacity: 1;
}

/* ===== TAB SYSTEM #2: Format Tabs ===== */
.colorpikr-tabs-secondary {
  display: flex;
  gap: 4px;
  margin-top: 12px;
  margin-bottom: 8px;
  background: var(--cp-bg-tertiary);
  padding: 4px;
  border-radius: var(--cp-border-radius);
  border: 1px solid var(--cp-border);
}

.colorpikr-format-tab {
  flex: 1;
  padding: 6px 12px;
  background: transparent;
  border: none;
  border-radius: 8px;
  color: var(--cp-text-secondary);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.5px;
  cursor: pointer;
  transition: all 0.3s ease;
}

.colorpikr-format-tab:hover {
  color: var(--cp-text-primary);
  background: rgba(255, 255, 255, 0.08);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
}

.colorpikr-format-tab.active {
  background: var(--cp-accent-gradient);
  color: #1a1a1a;
  box-shadow: var(--cp-accent-glow), 0 2px 8px rgba(0, 0, 0, 0.3);
}

/* ===== VALUE DISPLAY ===== */
.colorpikr-value-display {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 6px 8px;
  background: var(--cp-bg-tertiary);
  border-radius: var(--cp-border-radius);
  border: 1px solid var(--cp-border);
  margin-bottom: 12px;
  flex-wrap: nowrap;
  overflow: hidden;
  max-width: 100%;
}

.color-value-inputs {
  flex: 1;
  display: flex;
  gap: 4px;
  align-items: center;
  min-width: 0;
}

.color-input {
  background: var(--cp-input-bg);
  backdrop-filter: blur(8px);
  border: 1px solid var(--cp-input-border);
  border-radius: 8px;
  color: var(--cp-input-text);
  font-size: 14px;
  font-weight: 600;
  padding: 8px 14px;
  text-align: center;
  font-family: 'Courier New', monospace;
  transition: all 0.25s;
  outline: none;
  height: 36px;
  box-sizing: border-box;
  -webkit-appearance: none;
  -moz-appearance: textfield;
  appearance: textfield;
}

.color-input:hover {
  border-color: var(--cp-border-hover);
  background: var(--cp-bg-secondary);
}

.color-input:focus {
  border-color: var(--cp-accent);
  box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.3), 0 0 0 2px var(--cp-accent-secondary);
}

.color-input.hex-input {
  flex: 1;
  min-width: 70px;
}

.color-input.rgb-input,
.color-input.hsl-input,
.color-input.hsv-input {
  flex: 1;
  min-width: 40px;
}

/* Remove spinner arrows from number inputs */
.color-input::-webkit-inner-spin-button,
.color-input::-webkit-outer-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

.color-input[type="number"] {
  -moz-appearance: textfield;
  appearance: textfield;
}

.color-value-separator {
  color: var(--cp-text-tertiary);
  font-size: 11px;
  user-select: none;
}

.color-value-text {
  flex: 1;
  font-family: 'Courier New', monospace;
  font-size: 12px;
  font-weight: 700;
  color: var(--cp-text-primary);
  user-select: all;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  min-width: 0;
}

.color-copy-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  background: var(--cp-button-bg);
  backdrop-filter: blur(8px);
  border: 1px solid var(--cp-button-border);
  border-radius: 8px;
  color: var(--cp-text-primary);
  cursor: pointer;
  transition: all 0.3s ease;
  flex-shrink: 0;
  width: 36px;
  height: 36px;
  box-sizing: border-box;
  box-shadow: var(--cp-shadow-sm), var(--cp-shadow-inner);
}

.color-copy-btn:hover {
  background: var(--cp-button-hover);
  border-color: var(--cp-accent);
  color: var(--cp-text-primary);
  box-shadow: var(--cp-accent-glow), 0 2px 8px rgba(0, 0, 0, 0.3);
  transform: translateY(-1px);
}

.color-copy-btn:active {
  background: var(--cp-button-active);
  transform: translateY(0);
}

.color-copy-btn svg {
  flex-shrink: 0;
}

/* ===== BOTTOM BAR ===== */
.colorpikr-bottom-bar {
  display: flex;
  align-items: center;
  gap: 6px;
}

.current-color-box {
  width: 40px;
  height: 40px;
  flex-shrink: 0;
  border-radius: var(--cp-border-radius);
  border: 2px solid var(--cp-accent);
  cursor: pointer;
  transition: all 0.3s ease;
  box-shadow: var(--cp-shadow-sm), var(--cp-accent-glow), inset 0 1px 2px rgba(255, 255, 255, 0.1);
}

.current-color-box:hover {
  transform: scale(1.05);
  box-shadow: var(--cp-shadow-sm), 0 0 25px rgba(212, 156, 107, 0.5), inset 0 1px 2px rgba(255, 255, 255, 0.1);
}

.recent-colors-container {
  display: flex;
  gap: 3px;
  flex: 1;
  overflow: hidden;
  min-width: 0;
}

.recent-color-bar {
  flex: 1;
  min-width: 6px;
  max-width: 12px;
  height: 40px;
  border-radius: 3px;
  cursor: pointer;
  transition: all 0.2s;
  opacity: 0.5;
  background: var(--cp-bg-tertiary);
}

.recent-color-bar.filled {
  opacity: 1;
}

.recent-color-bar:hover {
  transform: scaleY(1.05);
  opacity: 1;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
}

.eyedropper-btn {
  width: 36px;
  height: 40px;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--cp-bg-tertiary);
  border: 1px solid var(--cp-border);
  border-radius: var(--cp-border-radius);
  color: var(--cp-text-secondary);
  cursor: pointer;
  transition: all 0.3s ease;
  box-shadow: var(--cp-shadow-sm), var(--cp-shadow-inner);
}

.eyedropper-btn:hover {
  background: var(--cp-bg-primary);
  border-color: var(--cp-border-hover);
  color: var(--cp-accent);
  transform: translateY(-1px);
  box-shadow: var(--cp-shadow-sm), var(--cp-accent-glow);
}

/* ===== MODE SWITCHER (Bottom Bar) - SVG Icons ===== */
.colorpikr-modes {
  display: flex;
  gap: 6px;
  align-items: center;
  margin-top: 12px;
}

.colorpikr-mode-btn {
  flex: 0 0 auto;
  width: 44px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--cp-bg-tertiary);
  backdrop-filter: blur(10px);
  border: 1px solid var(--cp-border);
  border-radius: var(--cp-border-radius);
  cursor: pointer;
  transition: all 0.3s ease;
  padding: 0;
  box-shadow: var(--cp-shadow-sm), var(--cp-shadow-inner);
}

.colorpikr-mode-btn svg {
  color: var(--cp-text-secondary);
  transition: all 0.3s ease;
  filter: drop-shadow(0 0 4px rgba(255, 255, 255, 0.1));
}

.colorpikr-mode-btn:hover {
  background: var(--cp-bg-primary);
  border-color: var(--cp-border-hover);
  box-shadow: var(--cp-shadow-sm), var(--cp-accent-glow);
  transform: translateY(-1px);
}

.colorpikr-mode-btn:hover svg {
  color: var(--cp-accent);
  filter: drop-shadow(0 0 8px rgba(212, 156, 107, 0.4));
}

.colorpikr-mode-btn.active {
  background: var(--cp-bg-primary);
  border-color: var(--cp-accent);
  box-shadow: var(--cp-shadow-sm), var(--cp-accent-glow), var(--cp-shadow-inner);
}

.colorpikr-mode-btn.active svg {
  color: var(--cp-accent);
  filter: drop-shadow(0 0 8px rgba(212, 156, 107, 0.5));
}

.mode-spacer {
  flex: 1;
  min-width: 8px;
}

.colorpikr-confirm-btn {
  flex: 0 0 auto;
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--cp-accent);
  border: none;
  border-radius: var(--cp-border-radius);
  cursor: pointer;
  transition: all 0.2s ease;
  padding: 0;
}

.colorpikr-confirm-btn svg {
  stroke: #ffffff;
  stroke-width: 3;
  fill: none;
  filter: drop-shadow(0 2px 4px rgba(0, 0, 0, 0.4));
}

.colorpikr-confirm-btn:hover {
  background: var(--cp-accent-hover);
  transform: scale(1.05);
}

/* Mode Pane Placeholders - FIXED HEIGHT */
.colorpikr-mode-pane {
  height: 320px;
  min-height: 320px;
  max-height: 320px;
  overflow: hidden;
  display: none;
}

.colorpikr-mode-pane.active {
  display: block;
}

.mode-placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 280px;
  color: var(--cp-text-secondary);
  font-size: 14px;
}

/* ===== TOAST NOTIFICATION ===== */
.colorpikr-toast {
  position: fixed;
  bottom: 20px;
  left: 50%;
  transform: translateX(-50%) translateY(100px);
  background: var(--cp-bg-tertiary);
  color: var(--cp-text-primary);
  padding: 12px 24px;
  border-radius: var(--cp-border-radius-lg);
  font-size: 14px;
  font-weight: 600;
  box-shadow: var(--cp-shadow);
  z-index: 10002;
  opacity: 0;
  transition: all 0.3s ease-out;
  pointer-events: none;
}

.colorpikr-toast.show {
  transform: translateX(-50%) translateY(0);
  opacity: 1;
}

/* ===== GRADIENT MODE STYLES (Compact & Clean) ===== */

/* Compress field height in gradient mode */
body[data-gradient-mode] #colorpikrSquare {
  aspect-ratio: 2.2 !important;
  margin-bottom: 8px !important;
}

body[data-gradient-mode] .colorpikr-slider-row {
  margin-bottom: 8px !important;
}

body[data-gradient-mode] .colorpikr-slider-row:last-child {
  margin-bottom: 4px !important;
}

/* Compress grid in gradient mode */
body[data-gradient-mode] .colorpikr-grid-container {
  padding: 4px !important;
  margin-bottom: 4px !important;
}

body[data-gradient-mode] .color-grid-row {
  gap: 2px !important;
  margin-bottom: 2px !important;
}

body[data-gradient-mode] .color-grid-cell {
  aspect-ratio: auto !important;
  height: 18px !important; /* Force shorter height */
}

body[data-gradient-mode] .colorpikr-grid-container + .colorpikr-slider-row {
  margin-top: 0 !important;
  margin-bottom: 6px !important;
}

/* Make pane content flex to push mode sections down */
#fieldPaneContent,
#gridPaneContent,
#slidersPaneContent,
#guidePaneContent {
  display: flex;
  flex-direction: column;
  height: 100%;
}

/* Gradient Tab Section - added to each tab */
.gradient-tab-section {
  margin-top: auto;
  padding-top: 8px;
  border-top: 2px solid var(--cp-border);
}

.gradient-bar-container {
  position: relative;
  margin-bottom: 8px;
  padding: 0 10px; /* Increased padding for thumbs */
  height: 24px;
  display: flex;
  align-items: center;
}

.gradient-bar-preview {
  width: 100%;
  height: 12px;
  border-radius: 12px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.3);
  position: relative;
  overflow: hidden;
  background-repeat: no-repeat;
  background-size: 100% 100%;
}

/* Thumbs wrapper - overlaid on top of the bar */
.gradient-bar-thumbs {
  position: absolute;
  top: 0;
  left: 10px; /* Match container padding */
  right: 10px; /* Match container padding */
  height: 100%;
  pointer-events: none;
  z-index: 10;
}

.gradient-thumb {
  position: absolute;
  width: 16px;
  height: 16px;
  margin-left: -8px; /* Center horizontally */
  top: 50%;
  transform: translateY(-50%);
  cursor: pointer;
  pointer-events: all;
  transition: transform 0.15s cubic-bezier(0.175, 0.885, 0.32, 1.275);
  z-index: 10;
}

.gradient-thumb:hover {
  transform: translateY(-50%) scale(1.15);
  z-index: 25;
}

.gradient-thumb.active {
  z-index: 20;
  transform: translateY(-50%) scale(1.1);
}

.gradient-thumb-indicator {
  width: 100%;
  height: 100%;
  border: 2px solid #ffffff;
  border-radius: 50%; /* Circle shape */
  position: relative;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.4), inset 0 0 0 1px rgba(0,0,0,0.2);
  background: inherit; /* Takes color from parent inline style */
}

.gradient-thumb.active .gradient-thumb-indicator {
  border-color: #ffffff;
  box-shadow: 0 0 0 2px var(--cp-accent-secondary), 0 4px 8px rgba(0, 0, 0, 0.5);
}

/* Remove old arrow styles */
.gradient-thumb::after {
  display: none;
}

.gradient-bar-controls {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 2px 4px;
  font-size: 11px;
}

/* Gradient Preview Window - Refined */
.gradient-preview-window {
  position: fixed;
  width: 220px;
  height: 240px;
  background: var(--cp-bg-secondary);
  border: 2px solid var(--cp-border);
  border-radius: 12px;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.5);
  z-index: 10001;
  display: none;
  cursor: move;
  overflow: hidden;
}

.gradient-preview-window.active {
  display: block;
}

.gradient-preview-header {
  padding: 10px 12px;
  background: var(--cp-bg-tertiary);
  border-bottom: 2px solid var(--cp-border);
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.gradient-preview-title {
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.5px;
  color: var(--cp-text-primary);
  text-transform: uppercase;
}

.gradient-preview-close {
  width: 20px;
  height: 20px;
  border-radius: 3px;
  background: transparent;
  border: none;
  color: var(--cp-text-primary);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s;
}

.gradient-preview-close:hover {
  background: var(--cp-bg-primary);
  color: var(--cp-accent);
}

.gradient-preview-content {
  width: 100%;
  height: calc(100% - 41px);
  padding: 12px;
}

.gradient-preview-display {
  width: 100%;
  height: 100%;
  border-radius: 8px;
  border: 1px solid var(--cp-border);
  box-shadow: inset 0 0 20px rgba(0, 0, 0, 0.2);
  background-repeat: no-repeat;
  background-size: 100% 100%;
}

/* Icon-only buttons (+ × 📋) */
.gradient-icon-btn {
  width: 20px;
  height: 20px;
  padding: 0;
  background: var(--cp-bg-tertiary);
  border: 2px solid var(--cp-border);
  border-radius: 3px;
  color: var(--cp-text-primary);
  cursor: pointer;
  transition: all 0.2s;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.gradient-icon-btn:hover:not(:disabled) {
  border-color: var(--cp-accent);
  background: var(--cp-bg-primary);
}

.gradient-icon-btn:disabled {
  opacity: 0.3;
  cursor: not-allowed;
}

.gradient-icon-btn svg {
  flex-shrink: 0;
}

[data-action="add"]:hover:not(:disabled) {
  border-color: var(--cp-accent);
  color: var(--cp-accent);
}

[data-action="delete"]:hover:not(:disabled) {
  border-color: #ff4444;
  color: #ff4444;
}

/* Copy button (accent bg) */
.gradient-copy-btn {
  background: var(--cp-accent);
  border-color: var(--cp-accent);
  color: #1a1a1a;
  margin-left: auto;
}

.gradient-copy-btn:hover {
  opacity: 0.9;
}

/* Divider */
.gradient-divider {
  width: 1px;
  height: 14px;
  background: var(--cp-border);
  flex-shrink: 0;
}

/* Type toggle (compact) */
.gradient-type-toggle {
  padding: 2px 8px;
  background: var(--cp-bg-tertiary);
  border: 2px solid var(--cp-border);
  border-radius: 3px;
  color: var(--cp-text-primary);
  font-size: 9px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s;
  white-space: nowrap;
  flex-shrink: 0;
  height: 20px;
  display: flex;
  align-items: center;
}

/* ===== GUIDE TAB RESPONSIVENESS FOR MODES ===== */
/* When any mode (Gradient, Contrast, Extract, Palettes) is active, 
   guide-container shrinks to make room for the bottom panel */

body[data-gradient-mode] .colorpikr-guide-container,
body[data-contrast-mode] .colorpikr-guide-container,
body[data-extract-mode] .colorpikr-guide-container,
body[data-palettes-mode] .colorpikr-guide-container {
  flex: initial !important;
  max-height: 60% !important;
  overflow-y: auto !important;
}

.gradient-type-toggle:hover {
  border-color: var(--cp-accent);
  background: var(--cp-bg-primary);
}

.gradient-type-toggle[data-type="linear"] {
  background: var(--cp-accent);
  border-color: var(--cp-accent);
  color: #1a1a1a;
}

/* Angle control (input + dial) - compact */
.gradient-angle-control {
  display: flex;
  align-items: center;
  gap: 3px;
  flex-shrink: 0;
}

.gradient-angle-input {
  width: 28px;
  height: 20px;
  padding: 2px 4px;
  background: var(--cp-bg-tertiary);
  border: 2px solid var(--cp-border);
  border-radius: 3px;
  color: var(--cp-text-primary);
  font-size: 9px;
  font-weight: 600;
  text-align: center;
  outline: none;
  /* Hide arrows */
  -moz-appearance: textfield;
  appearance: textfield;
}

.gradient-angle-input::-webkit-outer-spin-button,
.gradient-angle-input::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

.gradient-angle-input:focus {
  border-color: var(--cp-accent);
}

/* Rotary dial (compact) */
.gradient-angle-dial {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: var(--cp-bg-tertiary);
  border: 2px solid var(--cp-border);
  position: relative;
  cursor: pointer;
  transition: border-color 0.2s;
}

.gradient-angle-dial:hover {
  border-color: var(--cp-accent);
}

.gradient-angle-dial-indicator {
  position: absolute;
  top: 2px;
  left: 50%;
  transform-origin: center 8px;
  width: 2px;
  height: 6px;
  background: var(--cp-accent);
  margin-left: -1px;
  border-radius: 1px;
  transition: transform 0.1s;
}

/* ===== CONTRAST MODE STYLES (Compact like Gradient) ===== */

/* Compress field height in contrast mode */
body[data-contrast-mode] #colorpikrSquare {
  aspect-ratio: 2.2 !important;
  margin-bottom: 8px !important;
}

body[data-contrast-mode] .colorpikr-slider-row {
  margin-bottom: 8px !important;
}

body[data-contrast-mode] .colorpikr-slider-row:last-child {
  margin-bottom: 4px !important;
}

/* Compress grid in contrast mode */
body[data-contrast-mode] .colorpikr-grid-container {
  padding: 4px !important;
  margin-bottom: 4px !important;
}

body[data-contrast-mode] .color-grid-row {
  gap: 2px !important;
  margin-bottom: 2px !important;
}

body[data-contrast-mode] .color-grid-cell {
  aspect-ratio: auto !important;
  height: 18px !important; /* Force shorter height */
}

body[data-contrast-mode] .colorpikr-grid-container + .colorpikr-slider-row {
  margin-top: 0 !important;
  margin-bottom: 6px !important;
}

/* ===== CONTRAST CHECKER MODE ===== */

/* Contrast Panel Section - added to each tab (like gradient) */
.contrast-panel-section {
  margin-top: auto;
  padding-top: 8px;
  border-top: 2px solid var(--cp-border);
  display: flex;
  flex-direction: column;
  gap: 4px;
}

/* Compact 2-row layout */
.contrast-panel-row {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 2px 4px;
  font-size: 11px;
}

/* Color item (box + label) - compact */
.contrast-color-item {
  display: flex;
  align-items: center;
  gap: 3px;
  padding: 2px 5px;
  background: var(--cp-bg-tertiary);
  border: 2px solid var(--cp-border);
  border-radius: 3px;
  cursor: pointer;
  transition: all 0.2s;
  min-width: 52px;
  flex-shrink: 0;
}

.contrast-color-item:hover {
  border-color: var(--cp-accent);
  background: var(--cp-bg-primary);
}

.contrast-color-item.active {
  border-color: var(--cp-accent);
  box-shadow: 0 0 0 1px var(--cp-accent);
}

/* Color box (small square) */
.contrast-color-box {
  width: 12px;
  height: 12px;
  border-radius: 2px;
  border: 1px solid rgba(255, 255, 255, 0.2);
  flex-shrink: 0;
}

/* Color label */
.contrast-color-label {
  font-size: 9px;
  font-weight: 600;
  color: var(--cp-text-primary);
  text-transform: uppercase;
  letter-spacing: 0.2px;
}

/* WCAG item (N: AA ✓ style) */
.contrast-wcag-item {
  display: flex;
  align-items: center;
  gap: 2px;
  padding: 2px 5px;
  background: var(--cp-bg-tertiary);
  border: 1px solid var(--cp-border);
  border-radius: 2px;
  font-size: 9px;
  flex-shrink: 0;
}

.contrast-wcag-prefix {
  font-weight: 600;
  color: var(--cp-text-secondary);
}

.contrast-wcag-level {
  font-weight: 700;
  color: var(--cp-text-primary);
  font-size: 8px;
}

.contrast-wcag-status {
  font-size: 10px;
  font-weight: 700;
}

.contrast-wcag-status[data-status="pass"] {
  color: #4ade80;
}

.contrast-wcag-status[data-status="fail"] {
  color: #ff4444;
}

/* Contrast ratio (compact: 21:1 ✓) */
.contrast-ratio-display {
  display: flex;
  align-items: center;
  gap: 2px;
  margin-left: auto;
  padding: 2px 5px;
  background: var(--cp-bg-tertiary);
  border: 1px solid var(--cp-border);
  border-radius: 2px;
  font-size: 10px;
  flex-shrink: 0;
}

.contrast-ratio-value {
  font-weight: 700;
  color: var(--cp-text-primary);
}

.contrast-ratio-status {
  font-size: 10px;
  font-weight: 700;
}

.contrast-ratio-status[data-status="pass"] {
  color: #4ade80;
}

.contrast-ratio-status[data-status="fail"] {
  color: #ff4444;
}

/* Preview button */
.contrast-preview-btn {
  width: 20px;
  height: 20px;
  padding: 0;
  background: var(--cp-bg-tertiary);
  border: 2px solid var(--cp-border);
  border-radius: 3px;
  color: var(--cp-text-primary);
  cursor: pointer;
  transition: all 0.2s;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.contrast-preview-btn:hover {
  border-color: var(--cp-accent);
  background: var(--cp-bg-primary);
}

.contrast-preview-btn.active {
  background: var(--cp-accent);
  border-color: var(--cp-accent);
  color: #1a1a1a;
}

/* Info button (?) */
.contrast-info-btn {
  width: 20px;
  height: 20px;
  padding: 0;
  margin-left: auto;
  background: var(--cp-bg-tertiary);
  border: 2px solid var(--cp-border);
  border-radius: 3px;
  color: var(--cp-text-primary);
  cursor: pointer;
  transition: all 0.2s;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.contrast-info-btn:hover {
  border-color: var(--cp-accent);
  background: var(--cp-bg-primary);
}

.contrast-info-btn.active {
  background: var(--cp-accent);
  border-color: var(--cp-accent);
  color: #1a1a1a;
}

/* Preview Window (like gradient preview) */
.contrast-preview-window {
  position: fixed;
  width: 280px;
  height: 240px;
  background: var(--cp-bg-secondary);
  border: 2px solid var(--cp-border);
  border-radius: 12px;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.5);
  z-index: 10001;
  display: none;
  overflow: hidden;
}

.contrast-preview-window.active {
  display: block;
}

.contrast-preview-header {
  padding: 10px 12px;
  background: var(--cp-bg-tertiary);
  border-bottom: 2px solid var(--cp-border);
  display: flex;
  align-items: center;
  justify-content: space-between;
  cursor: move;
}

.contrast-preview-title {
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.5px;
  color: var(--cp-text-primary);
  text-transform: uppercase;
}

.contrast-preview-close {
  width: 20px;
  height: 20px;
  border-radius: 3px;
  background: transparent;
  border: none;
  color: var(--cp-text-primary);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s;
}

.contrast-preview-close:hover {
  background: var(--cp-bg-primary);
  color: var(--cp-accent);
}

.contrast-preview-content {
  width: 100%;
  height: calc(100% - 41px);
  padding: 12px;
}

.contrast-preview-sample {
  width: 100%;
  height: 100%;
  padding: 20px;
  border-radius: 8px;
  border: 1px solid var(--cp-border);
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 12px;
}

.sample-text-large {
  font-size: 20px;
  font-weight: 700;
  line-height: 1.3;
}

.sample-text-normal {
  font-size: 14px;
  line-height: 1.6;
}

/* Info Window (WCAG Guide) */
.contrast-info-window {
  position: fixed;
  width: 280px;
  max-height: 580px;
  background: var(--cp-bg-secondary);
  border: 2px solid var(--cp-border);
  border-radius: 12px;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.5);
  z-index: 10002;
  display: none;
  overflow: hidden;
}

.contrast-info-window.active {
  display: block;
}

.contrast-info-header {
  padding: 10px 12px;
  background: var(--cp-bg-tertiary);
  border-bottom: 2px solid var(--cp-border);
  display: flex;
  align-items: center;
  justify-content: space-between;
  cursor: move;
}

.contrast-info-title {
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.5px;
  color: var(--cp-text-primary);
  text-transform: uppercase;
}

.contrast-info-close {
  width: 20px;
  height: 20px;
  border-radius: 3px;
  background: transparent;
  border: none;
  color: var(--cp-text-primary);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s;
}

.contrast-info-close:hover {
  background: var(--cp-bg-primary);
  color: var(--cp-accent);
}

.contrast-info-content {
  padding: 16px;
  max-height: calc(580px - 41px);
  overflow-y: auto;
  font-size: 13px;
  line-height: 1.6;
  color: var(--cp-text-primary);
}

.info-section {
  margin-bottom: 16px;
}

.info-section:last-child {
  margin-bottom: 0;
}

.info-section h4 {
  margin: 0 0 8px 0;
  font-size: 14px;
  font-weight: 700;
  color: var(--cp-text-primary);
}

.info-section p {
  margin: 0 0 8px 0;
  color: var(--cp-text-primary);
}

.info-section ul,
.info-section ol {
  margin: 8px 0;
  padding-left: 20px;
}

.info-section li {
  margin-bottom: 4px;
}

.info-section strong {
  color: var(--cp-text-primary);
  font-weight: 700;
}

/* Scrollbar for info window */
.contrast-info-content::-webkit-scrollbar {
  width: 6px;
}

.contrast-info-content::-webkit-scrollbar-track {
  background: var(--cp-bg-primary);
  border-radius: 3px;
}

.contrast-info-content::-webkit-scrollbar-thumb {
  background: var(--cp-border);
  border-radius: 3px;
}

.contrast-info-content::-webkit-scrollbar-thumb:hover {
  background: var(--cp-accent);
}

/* ===== EXTRACT MODE STYLES (Compact like Gradient) ===== */

/* Compress field height in extract mode */
body[data-extract-mode] #colorpikrSquare {
  aspect-ratio: 2.2 !important;
  margin-bottom: 8px !important;
}

body[data-extract-mode] .colorpikr-slider-row {
  margin-bottom: 8px !important;
}

body[data-extract-mode] .colorpikr-slider-row:last-child {
  margin-bottom: 4px !important;
}

/* Compress grid in extract mode */
body[data-extract-mode] .colorpikr-grid-container {
  padding: 4px !important;
  margin-bottom: 4px !important;
}

body[data-extract-mode] .color-grid-row {
  gap: 2px !important;
  margin-bottom: 2px !important;
}

body[data-extract-mode] .color-grid-cell {
  aspect-ratio: auto !important;
  height: 18px !important;
}

body[data-extract-mode] .colorpikr-grid-container + .colorpikr-slider-row {
  margin-top: 0 !important;
  margin-bottom: 6px !important;
}

/* ===== COLOR EXTRACTION PANEL ===== */

/* Extract Panel Section - added to each tab (like gradient) */
.extract-panel-section {
  margin-top: auto;
  padding-top: 8px;
  border-top: 2px solid var(--cp-border);
  display: flex;
  flex-direction: column;
  gap: 4px;
}

/* Row 1: Upload + Count + Info */
.extract-control-row {
  display: flex;
  align-items: center;  /* Vertical center alignment */
  gap: 4px;
  padding: 2px 4px;
  height: 24px;  /* Fixed height */
  font-size: 11px;
}

/* Upload button */
.extract-upload-btn {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 3px 8px;
  background: var(--cp-bg-tertiary);
  border: 2px solid var(--cp-border);
  border-radius: 3px;
  color: var(--cp-text-primary);
  cursor: pointer;
  transition: all 0.2s;
  flex-shrink: 0;
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.3px;
}

.extract-upload-btn:hover {
  border-color: var(--cp-accent);
  background: var(--cp-bg-primary);
}

.extract-upload-btn svg {
  flex-shrink: 0;
}

/* Count control (slider + input) */
.extract-count-control {
  display: flex;
  align-items: center;  /* Vertical center alignment for slider + input */
  gap: 4px;
  flex: 1;
  min-width: 0;
}

.extract-count-slider {
  flex: 1;
  min-width: 40px;
  height: 5px;  /* Thinner track */
  -webkit-appearance: none;
  appearance: none;
  background: #888888;  /* SOLID GRAY - VISIBLE! */
  border-radius: 2px;
  cursor: pointer;
  outline: none;
}

.extract-count-slider::-webkit-slider-track {
  width: 100%;
  height: 100%;
  background: transparent;  /* Let slider background show through */
  border: none;
}

.extract-count-slider::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: var(--cp-accent-secondary-gradient);
  border: 2px solid var(--cp-bg-secondary);
  cursor: grab;
  margin-top: -0.5px;  /* Centered on 5px track */
  box-shadow: 0 2px 4px rgba(0,0,0,0.3);
}

.extract-count-slider::-webkit-slider-thumb:active {
  cursor: grabbing;
  transform: scale(1.1);
}

.extract-count-slider::-moz-range-track {
  width: 100%;
  height: 100%;
  background: transparent;  /* Let slider background show through */
  border: none;
}

.extract-count-slider::-moz-range-thumb {
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: var(--cp-accent-secondary-gradient);
  border: 2px solid var(--cp-bg-secondary);
  cursor: grab;
  box-shadow: 0 2px 4px rgba(0,0,0,0.3);
}

.extract-count-slider::-moz-range-thumb:active {
  cursor: grabbing;
}

.extract-count-input {
  width: 32px;
  padding: 2px 4px;
  background: var(--cp-bg-tertiary);
  border: 2px solid var(--cp-border);
  border-radius: 3px;
  color: var(--cp-text-primary);
  font-size: 10px;
  font-weight: 600;
  text-align: center;
  transition: all 0.2s;
}

.extract-count-input:hover {
  border-color: var(--cp-accent);
  background: var(--cp-bg-primary);
}

.extract-count-input:focus {
  outline: none;
  border-color: var(--cp-accent);
  background: var(--cp-bg-primary);
}

/* Remove spinner arrows */
.extract-count-input::-webkit-inner-spin-button,
.extract-count-input::-webkit-outer-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

.extract-count-input[type=number] {
  appearance: textfield;
  -moz-appearance: textfield;
}

/* Info button */
.extract-info-btn {
  width: 20px;
  height: 20px;
  padding: 0;
  margin-left: auto;
  background: var(--cp-bg-tertiary);
  border: 2px solid var(--cp-border);
  border-radius: 3px;
  color: var(--cp-text-primary);
  cursor: pointer;
  transition: all 0.2s;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.extract-info-btn:hover {
  border-color: var(--cp-accent);
  background: var(--cp-bg-primary);
}

.extract-info-btn.active {
  background: var(--cp-accent);
  border-color: var(--cp-accent);
  color: #1a1a1a;
}

/* Export Single Color button */
.extract-export-single-btn {
  width: 20px;
  height: 20px;
  padding: 0;
  background: var(--cp-bg-tertiary);
  border: 2px solid var(--cp-border);
  border-radius: 3px;
  color: var(--cp-text-primary);
  cursor: pointer;
  transition: all 0.2s;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.extract-export-single-btn:hover {
  border-color: var(--cp-accent);
  background: var(--cp-bg-primary);
  transform: scale(1.05);
}

.extract-export-single-btn:disabled {
  opacity: 0.3;
  cursor: not-allowed;
}

.extract-export-single-btn:disabled:hover {
  border-color: var(--cp-border);
  background: var(--cp-bg-tertiary);
  transform: none;
}

/* Export All to Palettes button */
.extract-export-btn {
  width: 20px;
  height: 20px;
  padding: 0;
  background: var(--cp-bg-tertiary);
  border: 2px solid var(--cp-border);
  border-radius: 3px;
  color: var(--cp-text-primary);
  cursor: pointer;
  transition: all 0.2s;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.extract-export-btn:hover {
  border-color: var(--cp-accent);
  background: var(--cp-bg-primary);
  transform: scale(1.05);
}

.extract-export-btn:disabled {
  opacity: 0.3;
  cursor: not-allowed;
}

.extract-export-btn:disabled:hover {
  border-color: var(--cp-border);
  background: var(--cp-bg-tertiary);
  transform: none;
}

/* Export to Palettes Dialog */
.extract-export-dialog-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.7);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 10001;
}

.extract-export-dialog {
  background: var(--cp-bg-secondary);
  border: 2px solid var(--cp-border);
  border-radius: 8px;
  width: 320px;
  max-width: 90%;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.5);
}

.extract-export-header {
  padding: 16px;
  background: var(--cp-bg-tertiary);
  border-bottom: 2px solid var(--cp-border);
  font-size: 14px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--cp-text-primary);
}

.extract-export-body {
  padding: 16px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.extract-export-choice-btn {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 16px;
  background: var(--cp-bg-tertiary);
  border: 2px solid var(--cp-border);
  border-radius: 6px;
  color: var(--cp-text-primary);
  cursor: pointer;
  transition: all 0.2s;
  font-size: 13px;
  font-weight: 500;
  text-align: left;
}

.extract-export-choice-btn:hover {
  border-color: var(--cp-accent);
  background: var(--cp-bg-primary);
  transform: translateX(4px);
}

.extract-export-choice-btn:disabled {
  opacity: 0.4;
  cursor: not-allowed;
}

.extract-export-choice-btn:disabled:hover {
  border-color: var(--cp-border);
  background: var(--cp-bg-tertiary);
  transform: none;
}

.extract-export-choice-btn svg {
  flex-shrink: 0;
}

.extract-export-list {
  padding: 12px;
  max-height: 300px;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.extract-palette-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px;
  background: var(--cp-bg-tertiary);
  border: 2px solid var(--cp-border);
  border-radius: 4px;
  color: var(--cp-text-primary);
  cursor: pointer;
  transition: all 0.2s;
  text-align: left;
}

.extract-palette-item:hover {
  border-color: var(--cp-accent);
  background: var(--cp-bg-primary);
}

.extract-palette-name {
  font-weight: 600;
  font-size: 13px;
}

.extract-palette-count {
  font-size: 11px;
  color: var(--cp-text-secondary);
}

.extract-export-footer {
  padding: 12px 16px;
  border-top: 2px solid var(--cp-border);
  display: flex;
  justify-content: flex-end;
}

.extract-export-cancel-btn {
  padding: 8px 16px;
  background: var(--cp-bg-tertiary);
  border: 2px solid var(--cp-border);
  border-radius: 4px;
  color: var(--cp-text-primary);
  cursor: pointer;
  transition: all 0.2s;
  font-size: 12px;
  font-weight: 600;
}

.extract-export-cancel-btn:hover {
  border-color: var(--cp-accent);
  background: var(--cp-bg-primary);
}

/* Row 2: Colors (PLP-style with horizontal scroll) */
.extract-colors-row {
  display: flex;
  align-items: center;
  justify-content: flex-start;  /* Changed from center for scroll */
  gap: 3px;
  padding: 4px;
  height: 32px;  /* Fixed height */
  background: var(--cp-bg-tertiary);
  border-radius: 3px;
  overflow-x: auto;
  overflow-y: hidden;
  cursor: grab;  /* Grab cursor for scrolling */
  scroll-behavior: smooth;
}

.extract-colors-row:active {
  cursor: grabbing;  /* Grabbing cursor when dragging */
}

/* Webkit scrollbar styling - matching PLP subtle style */
.extract-colors-row::-webkit-scrollbar {
  height: 6px;  /* Thicker for easier grabbing */
}

.extract-colors-row::-webkit-scrollbar-track {
  background: rgba(255, 255, 255, 0.05);
  border-radius: 2px;
}

.extract-colors-row::-webkit-scrollbar-thumb {
  background: rgba(255, 255, 255, 0.2);
  border-radius: 2px;
}

.extract-colors-row::-webkit-scrollbar-thumb:hover {
  background: rgba(255, 255, 255, 0.3);
}

/* Placeholder (no image) */
.extract-placeholder {
  width: 100%;
  text-align: center;
  padding: 4px;
  color: var(--cp-text-secondary);
  font-size: 9px;
  opacity: 0.4;
  font-style: italic;
}

/* CEP now uses .palette-color-swatch (defined in palettes section) */
/* Swatches in .extract-colors-row inherit PLP styling */

/* Info Window */
.extract-info-window {
  position: fixed;
  width: 280px;
  max-height: 600px;
  background: var(--cp-bg-secondary);
  border: 2px solid var(--cp-border);
  border-radius: 12px;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.5);
  z-index: 10002;
  display: none;
  overflow: hidden;
}

.extract-info-window.active {
  display: block;
}

.extract-info-header {
  padding: 10px 12px;
  background: var(--cp-bg-tertiary);
  border-bottom: 2px solid var(--cp-border);
  display: flex;
  align-items: center;
  justify-content: space-between;
  cursor: move;
}

.extract-info-title {
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.5px;
  color: var(--cp-text-primary);
  text-transform: uppercase;
}

.extract-info-close {
  width: 20px;
  height: 20px;
  border-radius: 3px;
  background: transparent;
  border: none;
  color: var(--cp-text-primary);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s;
}

.extract-info-close:hover {
  background: var(--cp-bg-primary);
  color: var(--cp-accent);
}

.extract-info-content {
  padding: 16px;
  max-height: calc(600px - 41px);
  overflow-y: auto;
  font-size: 13px;
  line-height: 1.6;
  color: var(--cp-text-primary);
}

/* Scrollbar for info window */
.extract-info-content::-webkit-scrollbar {
  width: 6px;
}

.extract-info-content::-webkit-scrollbar-track {
  background: var(--cp-bg-primary);
  border-radius: 3px;
}

.extract-info-content::-webkit-scrollbar-thumb {
  background: var(--cp-border);
  border-radius: 3px;
}

.extract-info-content::-webkit-scrollbar-thumb:hover {
  background: var(--cp-accent);
}

/* Drop Overlay (appears when dragging image over modal) */
.extract-drop-overlay {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.85);
  backdrop-filter: blur(8px);
  z-index: 10000;
  display: none;
  align-items: center;
  justify-content: center;
  pointer-events: none;
  border-radius: 12px;
}

.extract-drop-overlay.active {
  display: flex;
}

.extract-drop-content {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  color: var(--cp-text-primary);
  opacity: 0.9;
}

.extract-drop-content svg {
  opacity: 0.6;
}

.extract-drop-text {
  font-size: 18px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--cp-accent);
}

/* ===== PALETTES MODE ===== */

/* Compress field height in palettes mode */
body[data-palettes-mode] #colorpikrSquare {
  aspect-ratio: 2.2 !important;
  margin-bottom: 8px !important;
}

body[data-palettes-mode] .colorpikr-slider-row {
  margin-bottom: 8px !important;
}

body[data-palettes-mode] .colorpikr-slider-row:last-child {
  margin-bottom: 4px !important;
}

/* Compress grid in palettes mode */
body[data-palettes-mode] .colorpikr-grid-container {
  padding: 4px !important;
  margin-bottom: 4px !important;
}

body[data-palettes-mode] .color-grid-row {
  gap: 2px !important;
  margin-bottom: 2px !important;
}

body[data-palettes-mode] .color-grid-cell {
  aspect-ratio: auto !important;
  height: 18px !important;
}

body[data-palettes-mode] .colorpikr-grid-container + .colorpikr-slider-row {
  margin-top: 0 !important;
  margin-bottom: 6px !important;
}

/* Palettes Panel Section - Bottom aligned like Contrast/Extract */
.palettes-panel-section {
  display: flex;
  flex-direction: column;
  gap: 4px;
  margin-top: auto;  /* Push to bottom */
  padding-top: 8px;
  border-top: 2px solid var(--cp-border);
}

/* Row 1: Controls */
.palettes-control-row {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 2px 4px;
  height: 24px;  /* Fixed height like CEP */
  font-size: 11px;
}

.palettes-dropdown {
  flex: 0 1 auto;
  min-width: 70px;
  max-width: 95px;
  padding: 2px 4px;
  background: var(--cp-bg-tertiary);
  border: 2px solid var(--cp-border);
  border-radius: 3px;
  color: var(--cp-text-primary);
  cursor: pointer;
  font-size: 11px;
  transition: all 0.2s;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.palettes-dropdown:hover,
.palettes-dropdown:focus {
  border-color: var(--cp-accent);
  outline: none;
}

/* Make dropdown options wider when opened */
.palettes-dropdown option {
  min-width: 200px;
  padding: 4px 8px;
}

.palettes-dropdown option.palette-dropdown-new {
  font-weight: 700;
}

/* Control buttons */
.palettes-save-btn,
.palettes-rename-btn,
.palettes-delete-btn,
.palettes-export-btn,
.palettes-inverse-btn,
.palettes-add-btn,
.palettes-remove-btn,
.palettes-edit-btn,
.palettes-info-btn,
.palettes-extended-btn {
  width: 18px;
  height: 18px;
  padding: 2px;
  background: var(--cp-bg-tertiary);
  border: 2px solid var(--cp-border);
  border-radius: 3px;
  color: var(--cp-text-primary);
  cursor: pointer;
  transition: all 0.2s;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.palettes-save-btn:hover:not(:disabled),
.palettes-rename-btn:hover:not(:disabled),
.palettes-delete-btn:hover:not(:disabled),
.palettes-export-btn:hover:not(:disabled),
.palettes-inverse-btn:hover:not(:disabled),
.palettes-add-btn:hover:not(:disabled),
.palettes-remove-btn:hover:not(:disabled),
.palettes-edit-btn:hover:not(:disabled),
.palettes-info-btn:hover:not(:disabled),
.palettes-extended-btn:hover:not(:disabled) {
  border-color: var(--cp-accent);
  background: var(--cp-bg-primary);
}

.palettes-save-btn:disabled,
.palettes-rename-btn:disabled,
.palettes-delete-btn:disabled,
.palettes-export-btn:disabled,
.palettes-inverse-btn:disabled,
.palettes-add-btn:disabled,
.palettes-remove-btn:disabled,
.palettes-edit-btn:disabled,
.palettes-extended-btn:disabled {
  opacity: 0.3;
  cursor: not-allowed;
}

.palettes-edit-btn.active {
  border-color: var(--cp-accent);
  background: var(--cp-accent);
  color: #1a1a1a;
}

.palettes-spacer {
  flex: 1;
  min-width: 2px;
}

/* Row 2: Colors */
.palettes-colors-row {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 3px;
  padding: 4px;
  height: 32px;  /* Fixed height like CEP */
  background: var(--cp-bg-tertiary);
  border-radius: 3px;
  overflow-x: auto;
  overflow-y: hidden;
  cursor: grab;
  scroll-behavior: smooth;
}

.palettes-colors-row:active {
  cursor: grabbing;
}

/* Show subtle scrollbar */
.palettes-colors-row::-webkit-scrollbar {
  height: 6px;  /* Thicker for easier grabbing */
}

.palettes-colors-row::-webkit-scrollbar-track {
  background: rgba(255, 255, 255, 0.05);
  border-radius: 2px;
}

.palettes-colors-row::-webkit-scrollbar-thumb {
  background: rgba(255, 255, 255, 0.2);
  border-radius: 2px;
}

.palettes-colors-row::-webkit-scrollbar-thumb:hover {
  background: rgba(255, 255, 255, 0.3);
}

.palettes-placeholder {
  width: 100%;
  text-align: center;
  padding: 4px;
  color: var(--cp-text-secondary);
  font-size: 9px;
  opacity: 0.4;
  font-style: italic;
}

/* Color swatches */
.palette-color-swatch {
  width: 20px;
  height: 20px;
  background: var(--cp-bg-primary);
  border: 2px solid var(--cp-border);
  border-radius: 3px;
  cursor: pointer;
  transition: all 0.2s;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  flex-shrink: 0;
}

.palette-color-swatch:hover {
  border-color: var(--cp-accent);
  transform: scale(1.1);
}

.palette-color-swatch.selected {
  border-color: var(--cp-accent);
  box-shadow: 0 0 0 1px var(--cp-accent);
}

.palette-color-swatch.reorder-mode {
  cursor: grab;
}

.palette-color-swatch.reorder-mode:active {
  cursor: grabbing;
}

.palette-color-swatch.dragging {
  opacity: 0.4;
  transform: scale(0.9);
}

.palette-color-swatch.drag-over {
  border-color: var(--cp-accent);
  box-shadow: 0 0 0 2px var(--cp-accent);
  transform: scale(1.15);
}

/* Palettes Custom Dialogs (Prompt & Confirm) */
.palettes-dialog-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.7);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 10001;
}

.palettes-dialog {
  background: var(--cp-bg-secondary);
  border: 2px solid var(--cp-border);
  border-radius: 8px;
  padding: 20px;
  min-width: 300px;
  max-width: 400px;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.5);
}

.palettes-dialog-title {
  font-size: 14px;
  font-weight: 600;
  color: var(--cp-text-primary);
  margin-bottom: 16px;
}

.palettes-dialog-input {
  width: 100%;
  padding: 8px 12px;
  background: var(--cp-bg-tertiary);
  border: 2px solid var(--cp-border);
  border-radius: 4px;
  color: var(--cp-text-primary);
  font-size: 13px;
  font-family: inherit;
  margin-bottom: 16px;
  box-sizing: border-box;
}

.palettes-dialog-input:focus {
  outline: none;
  border-color: var(--cp-accent);
}

.palettes-dialog-buttons {
  display: flex;
  gap: 8px;
  justify-content: flex-end;
}

.palettes-dialog-btn {
  padding: 8px 16px;
  background: var(--cp-bg-tertiary);
  border: 2px solid var(--cp-border);
  border-radius: 4px;
  color: var(--cp-text-primary);
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s;
}

.palettes-dialog-btn:hover {
  border-color: var(--cp-accent);
  background: var(--cp-bg-primary);
}

.palettes-dialog-btn-primary {
  background: var(--cp-accent);
  border-color: var(--cp-accent);
  color: #1a1a1a;
}

.palettes-dialog-btn-primary:hover {
  opacity: 0.9;
  background: var(--cp-accent);
  border-color: var(--cp-accent);
}

.palettes-dialog-btn-danger {
  background: #d32f2f;
  border-color: #d32f2f;
  color: #fff;
}

.palettes-dialog-btn-danger:hover {
  opacity: 0.9;
  background: #d32f2f;
  border-color: #d32f2f;
}

/* Palettes Save Dialog (for Import) */
.palettes-save-dialog {
  min-width: 320px;
}

.palettes-save-options {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-bottom: 16px;
}

.palettes-save-option-btn {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 16px;
  background: var(--cp-bg-tertiary);
  border: 2px solid var(--cp-border);
  border-radius: 6px;
  color: var(--cp-text-primary);
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.2s;
  text-align: left;
}

.palettes-save-option-btn:hover {
  border-color: var(--cp-accent);
  background: var(--cp-bg-primary);
  transform: translateX(4px);
}

.palettes-save-option-btn svg {
  flex-shrink: 0;
  color: var(--cp-accent);
}

/* Palettes Info Window (Draggable) */
.palettes-info-window {
  position: fixed;
  width: 280px;
  background: var(--cp-bg-secondary);
  border: 2px solid var(--cp-border);
  border-radius: 8px;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.5);
  z-index: 10001;
  overflow: hidden;
}

.palettes-info-header {
  padding: 10px 12px;
  background: var(--cp-bg-tertiary);
  border-bottom: 2px solid var(--cp-border);
  display: flex;
  align-items: center;
  justify-content: space-between;
  cursor: move;
}

.palettes-info-title {
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.5px;
  color: var(--cp-text-primary);
  text-transform: uppercase;
}

.palettes-info-close {
  width: 20px;
  height: 20px;
  border-radius: 3px;
  background: transparent;
  border: none;
  color: var(--cp-text-primary);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s;
}

.palettes-info-close:hover {
  background: var(--cp-bg-primary);
  color: var(--cp-accent);
}

.palettes-info-content {
  padding: 16px;
  max-height: calc(600px - 41px);
  overflow-y: auto;
  font-size: 13px;
  line-height: 1.6;
  color: var(--cp-text-primary);
}

/* Scrollbar for palettes info window */
.palettes-info-content::-webkit-scrollbar {
  width: 6px;
}

.palettes-info-content::-webkit-scrollbar-track {
  background: var(--cp-bg-primary);
  border-radius: 3px;
}

.palettes-info-content::-webkit-scrollbar-thumb {
  background: var(--cp-border);
  border-radius: 3px;
}

.palettes-info-content::-webkit-scrollbar-thumb:hover {
  background: var(--cp-accent);
}

.palettes-info-content h4 {
  margin: 0 0 12px 0;
  font-size: 14px;
  font-weight: 700;
  color: var(--cp-text-primary);
}

.palettes-info-content p {
  margin: 0 0 10px 0;
  font-size: 13px;
  line-height: 1.6;
  color: var(--cp-text-primary);
}

.palettes-info-content ul {
  margin: 0 0 12px 0;
  padding-left: 20px;
}

.palettes-info-content li {
  margin-bottom: 6px;
  color: var(--cp-text-primary);
}

.palettes-info-content p:last-child {
  margin-bottom: 0;
}

.palettes-info-content strong {
  color: var(--cp-text-primary);
  font-weight: 600;
}

/* Backdrop Overlay (Over CPW only, dims CPW when IEW open) */
.palettes-backdrop {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.7);
  z-index: 9999;
  display: none;
  pointer-events: auto;
  animation: fadeIn 0.2s ease;
}

.palettes-backdrop.active {
  display: block;
}

@keyframes fadeIn {
  from { opacity: 0; }
  to { opacity: 1; }
}

/* Palettes Export/Import Window (Draggable) */
.palettes-export-import-window {
  position: fixed;
  width: 300px;
  max-height: calc(100vh - 20px);
  background: var(--cp-bg-secondary);
  border: 2px solid var(--cp-border);
  border-radius: 8px;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.5);
  z-index: 10001;
  overflow: hidden;
  left: 50%;
  top: 10px;
  transform: translateX(-50%);
}

.palettes-export-import-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 16px;
  background: var(--cp-bg-tertiary);
  border-bottom: 2px solid var(--cp-border);
  cursor: move;
  user-select: none;
}

.palettes-export-import-title {
  font-size: 13px;
  font-weight: 700;
  color: var(--cp-text-primary);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.palettes-export-import-close {
  width: 20px;
  height: 20px;
  padding: 4px;
  background: transparent;
  border: none;
  color: var(--cp-text-primary);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 3px;
  transition: all 0.2s;
}

.palettes-export-import-close:hover {
  background: var(--cp-bg-primary);
  color: var(--cp-accent);
}

.palettes-export-import-content {
  padding: 12px;
  max-height: calc(90vh - 50px);
  overflow-y: auto;
}

/* Palette Preview Carousel */
.palette-preview-section {
  margin-bottom: 12px;
  padding-top: 2px;
}

.palette-preview-carousel {
  display: flex;
  gap: 4px;
  overflow-x: auto;
  padding: 8px 0;
}

/* Custom scrollbar for carousel */
.palette-preview-carousel::-webkit-scrollbar {
  height: 6px;
}

.palette-preview-carousel::-webkit-scrollbar-track {
  background: var(--cp-bg-primary);
  border-radius: 3px;
}

.palette-preview-carousel::-webkit-scrollbar-thumb {
  background: var(--cp-accent);
  border-radius: 3px;
  transition: background 0.2s;
}

.palette-preview-carousel::-webkit-scrollbar-thumb:hover {
  background: var(--cp-accent-hover);
}

/* Firefox */
.palette-preview-carousel {
  scrollbar-width: thin;
  scrollbar-color: var(--cp-accent) var(--cp-bg-primary);
}

.palette-preview-swatch {
  min-width: 32px;
  height: 32px;
  border-radius: 4px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  flex-shrink: 0;
  cursor: pointer;
}

.palette-preview-empty {
  font-size: 11px;
  color: var(--cp-text-secondary);
  font-style: italic;
  padding: 8px 0;
}

/* Mode Toggle Section */
.mode-toggle-section {
  display: flex;
  gap: 8px;
  margin-bottom: 10px;
}

.mode-toggle-btn {
  flex: 1;
  padding: 10px;
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  background: var(--cp-bg-tertiary);
  color: var(--cp-text-secondary);
  border: 2px solid var(--cp-border);
  border-radius: 4px;
  cursor: pointer;
  transition: all 0.2s;
}

.mode-toggle-btn:hover {
  background: var(--cp-bg-primary);
  border-color: var(--cp-accent);
}

.mode-toggle-btn.active {
  background: var(--cp-accent);
  color: var(--cp-bg-primary);
  border-color: var(--cp-accent);
}

/* Format Section Label */
.format-section-label {
  font-size: 9px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.8px;
  color: var(--cp-text-secondary);
  margin-top: 4px;
  margin-bottom: 2px;
  padding-left: 2px;
  opacity: 0.7;
}

.format-section-label:first-child {
  margin-top: 0;
}

/* Format Buttons Row */
.format-buttons-row {
  display: flex;
  gap: 5px;
  margin-bottom: 2px;
  flex-wrap: wrap;
}

.format-btn {
  flex: 1;
  min-width: 60px;
  padding: 6px 5px;
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.3px;
  background: var(--cp-bg-tertiary);
  color: var(--cp-text-primary);
  border: 1px solid var(--cp-border);
  border-radius: 4px;
  cursor: pointer;
  transition: all 0.2s;
}

.format-btn:hover {
  background: var(--cp-bg-primary);
  border-color: var(--cp-accent);
  color: var(--cp-accent);
}

.format-btn:active {
  transform: scale(0.98);
}

/* Code Viewer Section */
.code-viewer-section {
  margin-top: 6px;
}

.code-viewer {
  width: 100%;
  min-height: 100px;
  max-height: 280px;
  padding: 8px;
  font-family: 'Courier New', monospace;
  font-size: 11px;
  line-height: 1.4;
  background: var(--cp-bg-primary);
  color: var(--cp-text-primary);
  border: 1px solid var(--cp-border);
  border-radius: 4px;
  resize: vertical;
  margin-bottom: 6px;
}

.code-viewer:focus {
  outline: none;
  border-color: var(--cp-accent);
}

/* Custom scrollbar for code viewer */
.code-viewer::-webkit-scrollbar {
  width: 8px;
}

.code-viewer::-webkit-scrollbar-track {
  background: var(--cp-bg-tertiary);
  border-radius: 4px;
}

.code-viewer::-webkit-scrollbar-thumb {
  background: var(--cp-accent);
  border-radius: 4px;
  transition: background 0.2s;
}

.code-viewer::-webkit-scrollbar-thumb:hover {
  background: var(--cp-accent-hover);
}

/* Firefox */
.code-viewer {
  scrollbar-width: thin;
  scrollbar-color: var(--cp-accent) var(--cp-bg-tertiary);
}

.code-actions {
  display: flex;
  gap: 6px;
}

.action-btn {
  flex: 1;
  min-width: 0;
  padding: 9px 8px;
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.3px;
  background: var(--cp-bg-tertiary);
  color: var(--cp-text-primary);
  border: 1px solid var(--cp-border);
  border-radius: 4px;
  cursor: pointer;
  transition: all 0.2s;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.action-btn:hover {
  background: var(--cp-bg-primary);
  border-color: var(--cp-accent);
}

.action-btn.primary {
  background: var(--cp-accent);
  color: var(--cp-bg-primary);
  border-color: var(--cp-accent);
}

.action-btn.primary:hover {
  background: var(--cp-accent-hover);
}

.action-btn:active {
  transform: scale(0.98);
}

.action-btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.action-btn:disabled:hover {
  background: var(--cp-bg-tertiary);
  border-color: var(--cp-border);
  transform: none;
}

/* Palettes Extended View Window (Draggable) */
.palettes-extended-window {
  position: fixed;
  width: 400px;
  height: 500px;
  background: var(--cp-bg-secondary);
  border: 2px solid var(--cp-border);
  border-radius: 8px;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.5);
  z-index: 10001;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

.palettes-extended-header {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  padding: 8px 12px;
  background: var(--cp-bg-tertiary);
  border-bottom: 2px solid var(--cp-border);
  cursor: move;
  user-select: none;
  flex-shrink: 0;
  min-height: 32px;
}

.palettes-extended-controls {
  display: flex;
  align-items: center;
  gap: 6px;
}

.palettes-extended-size-btn {
  width: 20px;
  height: 20px;
  padding: 4px;
  background: transparent;
  border: none;
  color: var(--cp-text-primary);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 3px;
  transition: all 0.2s;
}

.palettes-extended-size-btn:hover {
  background: var(--cp-bg-primary);
  color: var(--cp-accent);
}

.palettes-extended-close {
  width: 20px;
  height: 20px;
  padding: 4px;
  background: transparent;
  border: none;
  color: var(--cp-text-primary);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 3px;
  transition: all 0.2s;
  margin-left: 6px;
}

.palettes-extended-close:hover {
  background: var(--cp-bg-primary);
  color: var(--cp-accent);
}

.palettes-extended-content {
  padding: 16px;
  overflow-y: auto;
  flex: 1;
}

.palettes-extended-grid {
  display: grid;
  /* grid-template-columns set inline with swatch size */
}

.palettes-extended-swatch {
  /* width and height set inline with swatch size */
  border: 2px solid var(--cp-border);
  border-radius: 6px;
  cursor: pointer;
  transition: all 0.2s;
  position: relative;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  flex-shrink: 0;
}

.palettes-extended-swatch:hover {
  border-color: var(--cp-accent);
  transform: scale(1.05);
  z-index: 10;
}

.palettes-extended-swatch.selected {
  border-color: var(--cp-accent);
  box-shadow: 0 0 0 2px var(--cp-accent);
  transform: scale(1.05);
}

.palettes-extended-swatch.reorder-mode {
  cursor: grab;
}

.palettes-extended-swatch.reorder-mode.dragging {
  opacity: 0.5;
  cursor: grabbing;
}

.palettes-extended-swatch.reorder-mode.drag-over {
  border-color: var(--cp-accent);
  background: rgba(255, 255, 255, 0.1);
}

/* Resize handle */
.palettes-resize-handle {
  position: absolute;
  bottom: 0;
  right: 0;
  width: 20px;
  height: 20px;
  cursor: nwse-resize;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--cp-text-secondary);
  opacity: 0.6;
  transition: opacity 0.2s;
}

.palettes-resize-handle:hover {
  opacity: 1;
  color: var(--cp-accent);
}

.palettes-resize-handle svg {
  transform: rotate(90deg);
}

/* Palette Reorder Dialog */
.palettes-reorder-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.7);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 10002;
}

.palettes-reorder-dialog {
  background: var(--cp-bg-secondary);
  border: 2px solid var(--cp-border);
  border-radius: 6px;
  width: 300px;
  max-height: 500px;
  display: flex;
  flex-direction: column;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.5);
}

.palettes-reorder-header {
  padding: 12px 16px;
  border-bottom: 2px solid var(--cp-border);
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: 13px;
  font-weight: 700;
  color: var(--cp-text-primary);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.palettes-reorder-close {
  background: transparent;
  border: none;
  color: var(--cp-text-primary);
  cursor: pointer;
  font-size: 18px;
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 3px;
  transition: all 0.2s;
}

.palettes-reorder-close:hover {
  background: var(--cp-bg-primary);
  color: var(--cp-accent);
}

.palettes-reorder-list {
  flex: 1;
  overflow-y: auto;
  padding: 8px;
  min-height: 200px;
}

.palettes-reorder-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 12px;
  margin-bottom: 4px;
  background: var(--cp-bg-tertiary);
  border: 2px solid var(--cp-border);
  border-radius: 4px;
  cursor: grab;
  transition: all 0.2s;
  user-select: none;
}

.palettes-reorder-item:hover {
  border-color: var(--cp-accent);
  background: var(--cp-bg-primary);
}

.palettes-reorder-item.dragging {
  opacity: 0.5;
  cursor: grabbing;
}

.palettes-reorder-item.drag-over {
  border-color: var(--cp-accent);
  background: rgba(255, 255, 255, 0.1);
  transform: scale(1.02);
}

.palettes-reorder-item svg {
  color: var(--cp-text-secondary);
  flex-shrink: 0;
}

.palettes-reorder-item span {
  flex: 1;
  color: var(--cp-text-primary);
  font-size: 12px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.palettes-reorder-footer {
  padding: 12px 16px;
  border-top: 2px solid var(--cp-border);
  display: flex;
  justify-content: flex-end;
}

.palettes-reorder-save-btn {
  padding: 8px 16px;
  background: var(--cp-accent);
  border: none;
  border-radius: 4px;
  color: #1a1a1a;
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
  transition: all 0.2s;
}

.palettes-reorder-save-btn:hover {
  background: var(--cp-accent-hover);
  transform: scale(1.02);
}
