/* ============================================
   TEST.CSS - "Buy Box" PDP Layout Prototype
   Matches Minimalista Theme
   ============================================ */

@import url('https://fonts.googleapis.com/css2?family=Instrument+Sans:ital,wght@0,400;0,500;0,600;1,400&display=swap');

:root {
  /* --- Minimalista Design Tokens --- */
  --color-background: 249, 249, 249;
  --color-foreground: 40, 40, 40;
  --color-border: 229, 229, 229;
  --color-foreground-secondary: 105, 105, 105;
  
  --header-height-desktop: 0px;
  --header-height-mobile: 0px;
  --sidebar-header-height: 40px;
  --category-bar-height: 90px;
	--footer-height: 60px;
  --sidebar-width: clamp(340px, 28vw, 420px);
  
  --font-family-base: "Instrument Sans", sans-serif;
}

* { margin: 0; padding: 0; box-sizing: border-box; }

body {
  font-family: var(--font-family-base);
  background-color: rgb(var(--color-background));
  color: rgb(var(--color-foreground));
  height: 100vh;
  width: 100vw;
  overflow: hidden;
}

#root {
  display: flex;
  flex-direction: column;
  height: 100%;
}

/* ============================================
   1. SIMULATED HEADER (Hidden - nav moves to sidebar)
   ============================================ */
.simulated-header {
  display: none;
}

/* Sidebar Header */
.sidebar-header {
  height: var(--sidebar-header-height);
  padding: 0 20px;
  border-bottom: 1px solid rgb(var(--color-border));
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-shrink: 0;
}

.back-link {
  font-size: 12px;
  color: rgb(var(--color-foreground-secondary));
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: 6px;
}

.back-link:hover {
  color: rgb(var(--color-foreground));
}

.sidebar-logo {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: rgb(var(--color-foreground-secondary));
}

/* ============================================
   2. LAYOUT LOGIC (Minimalista Breakpoints)
   ============================================ */

/* --- BASE (Mobile-First / < 750px) --- */
/* Vertical Stack Layout */
#root {
  display: flex;
  flex-direction: column;
  height: 100vh;
  width: 100vw;
  overflow: hidden;
}

.simulated-header {
  height: var(--header-height-mobile);
  padding: 0 1.5rem;
  flex-shrink: 0;
}

.header-nav { display: none; }

/* Canvas takes top half (minus header) */
.canvas-container {
  position: relative !important;
  width: 100% !important;
  height: 45vh !important; /* Adjust for balance */
  background-color: rgb(var(--color-background));
  border-bottom: 1px solid rgb(var(--color-border));
  z-index: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

#renderCanvas {
  width: 100% !important;
  height: 100% !important;
  outline: none;
}

.ui-overlay-container { display: none; }

/* Nav Tabs (Left Panel) -> Fixed Bottom Bar */
#left-main-panel,
.panel-left-main {
  position: fixed !important;
  bottom: 0 !important;
  left: 0 !important;
  width: 100% !important;
  height: var(--footer-height) !important;
  top: auto !important;
  
  background: #ffffff !important;
  border-top: 1px solid rgb(var(--color-border));
  border-radius: 0 !important;
  box-shadow: 0 -4px 20px rgba(0,0,0,0.05) !important;
  z-index: 50;
  
  display: flex !important;
  flex-direction: row !important;
}

#left-main-panel .category-list {
  display: flex !important;
  flex-direction: row !important;
  width: auto;
  justify-content: center;
  gap: 10px;
  padding: 0;
}

#left-main-panel .category-button {
  flex: 1;
  flex-direction: column !important;
  justify-content: center;
  height: 100% !important;
  padding: 0 !important;
  margin: 0 !important;
  border: none !important;
  border-top: 3px solid transparent !important;
  font-size: 11px !important;
  color: rgb(var(--color-foreground-secondary)) !important;
  background: transparent !important;
}

#left-main-panel .category-button.active {
  border-top-color: rgb(var(--color-foreground)) !important;
  color: rgb(var(--color-foreground)) !important;
}

/* Control Panel (Right Panel) -> Fills space between Canvas and Bottom Nav */
#right-main-panel,
.panel-right-main {
  position: absolute !important;
  top: calc(var(--header-height-mobile) + 45vh) !important;
  bottom: var(--footer-height) !important;
  left: 0 !important;
  width: 100% !important;
  height: auto !important;
  
  background: #ffffff !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  
  display: flex !important;
  flex-direction: column;
  z-index: 20;
  padding-top: 0 !important;
}

/* --- TABLET (750px - 1099px) --- */
@media (min-width: 750px) and (max-width: 1099px) {
  .canvas-container {
    height: 55vh !important; /* More canvas on tablet */
  }
  
  #right-main-panel,
  .panel-right-main {
    top: calc(var(--header-height-mobile) + 55vh) !important;
  }
}

/* --- DESKTOP (1100px+) --- */
/* Grid Layout / Buy Box */
@media (min-width: 1100px) {
  /* Unhide overlay container so panels render */
  .ui-overlay-container { display: block !important; }

  #root {
    display: grid;
    grid-template-rows: 1fr;
    grid-template-columns: 1fr var(--sidebar-width);
    grid-template-areas: "canvas sidebar";
    height: 100vh;
  }

  .canvas-container {
    grid-area: canvas;
    height: 100% !important; /* Fill grid cell */
    border-bottom: none;
  }

  /* Sidebar Container */
  #right-main-panel, 
  .panel-right-main {
    position: fixed !important;
    top: calc(var(--sidebar-header-height) + var(--category-bar-height)) !important;
    right: 0 !important;
    bottom: var(--footer-height) !important;
    left: auto !important;
    width: var(--sidebar-width) !important;
    height: auto !important;
    
    border-left: 1px solid rgb(var(--color-border));
    z-index: 20;
    pointer-events: auto;
  }

  /* Nav Tabs (Top of Sidebar) */
  #left-main-panel,
  .panel-left-main {
    position: fixed !important;
    top: var(--sidebar-header-height) !important;
    right: 0 !important;
    bottom: auto !important;
    left: auto !important;
    width: var(--sidebar-width) !important;
    height: var(--category-bar-height) !important;
    
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    
    border-top: none;
    border-bottom: 1px solid rgb(var(--color-border));
    border-left: 1px solid rgb(var(--color-border));
    box-shadow: none !important;
    z-index: 30;
  }

  /* Sidebar Footer - CTA Buttons */
  .sidebar-footer {
    position: fixed;
    bottom: 0;
    right: 0;
    width: var(--sidebar-width);
    height: var(--footer-height);
    background: rgb(var(--color-background));
    border-top: 1px solid rgb(var(--color-border));
    border-left: 1px solid rgb(var(--color-border));
    display: flex;
    gap: 12px;
    padding: 12px 16px;
    z-index: 30;
  }

  .sidebar-cta {
    flex: 1;
    height: 36px;
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    border: none;
		border-radius: 4px;
    cursor: pointer;
    transition: background-color 0.2s, color 0.2s;
  }

  .sidebar-cta-secondary {
    background: transparent;
    border: 1px solid rgb(var(--color-border));
    color: rgb(var(--color-foreground));
  }

  .sidebar-cta-secondary:hover {
    border-color: rgb(var(--color-foreground));
  }

  .sidebar-cta-primary {
    background: rgb(var(--color-foreground));
    color: rgb(var(--color-background));
  }

  .sidebar-cta-primary:hover {
    background: rgb(var(--color-foreground-secondary));
  }
  
  #left-main-panel .category-button {
    flex-direction: row !important;
    height: 36px;
    padding: 5px 12px !important;
    font-size: 13px !important;
    font-weight: 500 !important;
    letter-spacing: 0.08em !important;
    color: rgb(var(--color-foreground)) !important;
    transparent !important;
    border: 1px solid rgb(var(--color-border)) !important;
    border-radius: 4px !important;
    transition: border-color 250ms;
  }
  
  #left-main-panel .category-button:hover {
    border-color: rgb(var(--color-foreground)) !important;
  }
  
  #left-main-panel .category-button.active {
    border-color: rgb(var(--color-foreground)) !important;
    transparent !important;
  }
}

/* ============================================
   4. COMPONENT OVERRIDES
   ============================================ */

/* Thumbnail Grid - Archetype/Style Selection */
.thumbnail-grid {
  display: grid;
  grid-template-columns: 1fr; /*repeat(2, 1fr);*/
  gap: 12px;
  padding: 16px;
}

.thumbnail-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 0;
  background: rgb(var(--color-background));
  border: 1px solid rgb(var(--color-border));
  border-radius: 0;
  cursor: pointer;
  transition: border-color 0.2s;
  overflow: hidden;
}

.thumbnail-card:hover {
  border-color: rgb(var(--color-foreground));
}

.thumbnail-card.selected {
  border-color: rgb(var(--color-foreground));
  border-width: 2px;
}

.thumbnail-card.disabled {
  opacity: 0.4;
  cursor: not-allowed;
}

.thumbnail-card img {
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  display: block;
}

.thumbnail-label {
  width: 100%;
  padding: 8px;
  font-size: 11px;
  font-weight: 500;
  text-align: center;
  color: rgb(var(--color-foreground));
  background: rgb(var(--color-background));
  border-top: 1px solid rgb(var(--color-border));
}

.thumbnail-placeholder {
  width: 100%;
  aspect-ratio: 1 / 1;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(0,0,0,0.03);
  font-size: 24px;
  font-weight: 600;
  color: rgb(var(--color-foreground-secondary));
}

.thumbnail-color-swatch {
  width: 100%;
  aspect-ratio: 1 / 1;
}

/* Wood Species Image Grid */
.wood-species-image-grid {
  display: flex;
  flex-direction: column;
  gap: 16px;
  padding: 16px;
}

.species-card {
  padding: 12px;
  background: rgb(var(--color-background));
  border: 1px solid rgb(var(--color-border));
  border-radius: 0;
  transition: border-color 0.2s;
}

.species-card.active {
  border-color: rgb(var(--color-foreground));
  border-width: 2px;
}

.species-label {
  font-size: 12px;
  font-weight: 500;
  color: rgb(var(--color-foreground));
  margin-bottom: 12px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.grain-thumbnail-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 6px;
}

.grain-thumbnail {
  position: relative;
  width: 100%;
  aspect-ratio: 1 / 1;
  padding: 0;
  border: 1px solid rgb(var(--color-border));
  border-radius: 0;
  background: rgb(var(--color-background));
  cursor: pointer;
  overflow: hidden;
  transition: border-color 0.2s;
}

.grain-thumbnail:hover {
  border-color: rgb(var(--color-foreground));
}

.grain-thumbnail.selected {
  border-color: rgb(var(--color-foreground));
  border-width: 2px;
}

.grain-thumbnail img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Room Selector */
.room-selector {
  display: flex;
  flex-direction: column;
  gap: 16px;
  padding: 16px;
}

.room-thumbnail-wrapper {
  width: 100%;
}

.room-thumbnail {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
  border: 1px solid rgb(var(--color-border));
  border-radius: 0;
  background: rgb(var(--color-background));
  cursor: pointer;
  overflow: hidden;
  transition: border-color 0.2s;
}

.room-thumbnail:hover {
  border-color: rgb(var(--color-foreground));
}

.room-thumbnail.selected {
  border-color: rgb(var(--color-foreground));
  border-width: 2px;
}

.room-thumbnail-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Fix Upload Zone to fit in sidebar */
.upload-zone {
  height: auto !important;
  min-height: 300px;
  aspect-ratio: 1 / 1;
  background: transparent !important;
  border: 2px dashed rgb(var(--color-border)) !important;
  border-radius: 0 !important;
  margin: 20px;
  width: calc(100% - 40px) !important;
}

.upload-icon {
  color: rgb(var(--color-foreground-secondary)) !important;
}

.upload-zone.drag-over {
  border-color: rgb(var(--color-foreground)) !important;
  background-color: rgba(0,0,0,0.03) !important;
}

/* Fix Texture Loading Indicator positioning */
.texture-loading-indicator {
  top: auto !important;
  bottom: 20px !important;
  left: 20px !important;
  right: auto !important;
  background: rgba(255,255,255,0.9) !important;
  border: 1px solid rgb(var(--color-border)) !important;
  color: rgb(var(--color-foreground)) !important;
  box-shadow: 0 2px 10px rgba(0,0,0,0.05) !important;
}

.loading-text {
  color: rgb(var(--color-foreground)) !important;
}

.loading-spinner-small {
  border-color: rgba(0,0,0,0.1) !important;
  border-top-color: rgb(var(--color-foreground)) !important;
}

/* Processing Overlay - Contain to Canvas */
.processing-overlay {
  position: absolute !important;
  inset: 0 !important;
  z-index: 10 !important;
  background: rgba(255,255,255,0.8) !important;
  backdrop-filter: blur(5px);
}

.processing-message {
  color: rgb(var(--color-foreground)) !important;
}

.processing-progress-bar {
  background: rgba(0,0,0,0.1) !important;
}

.processing-progress-fill {
  background: rgb(var(--color-foreground)) !important;
}

/* Hide legacy upload container from root */
#uploadContainer {
  /* Move this into the sidebar flow via JS or hide it if it's duplicates */
  display: none !important; 
}

/* Force the UploadPanel content (which is inside .panel-right-main) to fit */
.upload-panel {
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

/* Fix the Processing Overlay to cover ONLY the canvas, not the header/sidebar */
.processing-overlay {
  position: absolute !important; /* Float ON TOP of canvas */
  top: 0;
  left: 0;
  width: 100% !important;
  height: 100% !important;
  z-index: 50 !important;
  background: rgba(249, 249, 249, 0.95) !important; /* Match theme bg */
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  pointer-events: all; /* Block clicks while processing */
  
  /* Transition props inherited from style.css, but we must respect visibility */
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease, visibility 0.3s ease;
}

.processing-overlay.active {
  opacity: 1 !important;
  visibility: visible !important;
}

/* Ensure canvas container is the positioning context */
.canvas-container {
  position: relative !important;
  display: block !important; /* Force block to contain absolute children properly */
}

/* Force canvas to fill container absolutely to avoid layout shifts */
#renderCanvas {
  position: absolute !important;
  top: 0;
  left: 0;
  width: 100% !important;
  height: 100% !important;
  outline: none;
}

/* Ensure Sidebar handles overflow properly */
#right-main-panel, 
.panel-right-main {
  overflow-y: auto !important;
  overflow-x: hidden !important;
}

/* Loading Text Adjustment 
.texture-loading-indicator {
  z-index: 60 !important;
  position: absolute !important;
  left: 20px !important;
  bottom: 20px !important;
  top: auto !important;
  right: auto !important;
}*/

/* Loading Text Adjustment - Hidden during testing */
.texture-loading-indicator {
  display: none !important;
}

/* ============================================
   BACKING PANEL / COLOR SWATCHES
   ============================================ */
.color-group-card {
  padding: 12px;
  background-color: rgba(0, 0, 0, 0.02);
  border: 1px solid rgb(var(--color-border));
  border-radius: 0;
  margin-bottom: 16px;
}

/* Backing Toggle - Sticky Header */
.backing-toggle-header {
  position: sticky;
  top: 0;
  z-index: 5;
  background: rgb(var(--color-background));
  padding: 12px 16px;
  border-bottom: 1px solid rgb(var(--color-border));
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.backing-toggle-label {
  font-size: 13px;
  font-weight: 500;
  color: rgb(var(--color-foreground));
  white-space: nowrap;
}

.backing-toolbar-toggle .toggle-switch {
  flex-shrink: 0;
}

.backing-toolbar-toggle {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 8px;
  padding: 4px 12px;
}

/* Toggle Switch - Minimalista Style */
.toggle-switch {
  position: relative;
  display: inline-block;
  width: 40px;
  height: 22px;
}

.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: rgb(var(--color-border));
  transition: 0.3s;
  border-radius: 22px;
}

.toggle-slider:before {
  position: absolute;
  content: "";
  height: 16px;
  width: 16px;
  left: 3px;
  bottom: 3px;
  background-color: white;
  transition: 0.3s;
  border-radius: 50%;
}

input:checked + .toggle-slider {
  background-color: rgb(var(--color-foreground));
}

input:checked + .toggle-slider:before {
  transform: translateX(18px);
}

.color-group-label {
  font-size: 12px;
  font-weight: 500;
  color: rgb(var(--color-foreground));
  margin-bottom: 12px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.color-swatch-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;
}

.color-swatch {
  position: relative;
  width: 100%;
  aspect-ratio: 1 / 1;
  padding: 0;
  border: 1px solid rgb(var(--color-border));
  border-radius: 0;
  background-color: rgb(var(--color-background));
  cursor: pointer;
  overflow: hidden;
  transition: border-color 0.2s;
}

.color-swatch:hover {
  border-color: rgb(var(--color-foreground));
}

.color-swatch.selected {
  border-color: rgb(var(--color-foreground));
  border-width: 2px;
}

.color-swatch-fill {
  width: 100%;
  height: 100%;
}

/* ============================================
   TOOLTIPS
   ============================================ */
.tooltip-archetype,
.tooltip-paint,
.tooltip-accent,
.tooltip-rooms,
.tooltip-species,
.tooltip-backing,
.tooltip-grid,
.tooltip-section,
.tooltip-filter {
  position: fixed;
  background: transparent;
  border: none;
  border-radius: 0;
  padding: 0;
  z-index: 10000;
  pointer-events: none;
  max-width: 400px;
}

.tooltip-content-wrapper {
  display: flex;
  flex-direction: column;
  background: rgb(var(--color-foreground));
}

.tooltip-content-wrapper img {
  width: 100%;
  height: auto;
  border-radius: 0;
  display: block;
}

.tooltip-description {
  width: 100%;
  padding: 12px 16px;
  font-size: 13px;
  line-height: 1.5;
  color: rgb(var(--color-background));
  margin: 0;
  white-space: pre-line;
}

.tooltip-color-swatch {
  width: 400px;
  height: 400px;
}

/* Help Icon & Tooltip */
.panel-help-icon {
  background: transparent;
  border: 1px solid rgb(var(--color-border));
  border-radius: 50%;
  width: 20px;
  height: 20px;
  font-size: 12px;
  font-weight: 600;
  color: rgb(var(--color-foreground-secondary));
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: border-color 0.2s, color 0.2s;
}

.panel-help-icon:hover {
  border-color: rgb(var(--color-foreground));
  color: rgb(var(--color-foreground));
}

.tooltip-filter,
.tooltip-section {
  position: fixed;
  padding: 6px 12px;
  font-size: 13px;
  font-weight: 500;
  pointer-events: none;
  z-index: 10000;
  white-space: nowrap;
  background: rgb(var(--color-foreground));
  color: rgb(var(--color-background));
}

.tooltip-help {
  position: fixed;
  z-index: 10000;
  max-width: 320px;
  overflow-y: auto;
  padding: 14px 18px;
  font-size: 13px;
  line-height: 1.5;
  white-space: pre-line;
  background: rgb(var(--color-foreground));
  border: none;
  border-radius: 0;
  color: rgb(var(--color-background));
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
}

.tooltip-help::-webkit-scrollbar {
  width: 6px;
}

.tooltip-help::-webkit-scrollbar-track {
  background: rgba(128, 128, 128, 0.2);
}

.tooltip-help::-webkit-scrollbar-thumb {
  background: rgba(128, 128, 128, 0.5);
  border-radius: 3px;
}


/* ============================================
   SLIDERS (Layout controls)
   ============================================ */
.slider-group {
  display: flex;
  flex-direction: column;
  gap: 30px;
  padding: 30px;
  margin-bottom: 16px;
}

.slider-control {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.slider-label-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 4px;
}

.slider-label-row label {
  font-size: 13px;
  font-weight: 500;
  color: rgb(var(--color-foreground));
  text-transform: capitalize;
}

.slider-value {
  font-size: 14px;
  font-weight: 600;
  min-width: 50px;
  text-align: right;
}

.slider-container {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-top: 8px;
}

.slider-input {
  width: 100%;
  -webkit-appearance: none;
  appearance: none;
  height: 4px;
  background: rgba(0, 0, 0, 0.15);
  border-radius: 2px;
  outline: none;
}

.slider-input::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 16px;
  height: 16px;
  background: rgb(var(--color-foreground));
  border-radius: 50%;
  cursor: pointer;
}

.slider-input::-moz-range-thumb {
  width: 16px;
  height: 16px;
  background: rgb(var(--color-foreground));
  border: none;
  border-radius: 50%;
  cursor: pointer;
}

/* DEPRECATED: Section toolbar embedded in accordion headers
#right-secondary-panel,
.panel-right-secondary {
  display: none !important;
}
*/

.section-selector-panel {
  display: flex;
  flex-direction: row;
  align-items: center;
}

.section-icon-column {
  display: flex;
  flex-direction: row;
  gap: 4px;
  padding: 4px 0;
  align-items: center;
}

.section-selector-panel .panel-body {
  padding: 0;
  overflow: visible;
}

.section-icon-button {
  position: relative;
  width: 42px;
  height: 42px;
  padding: 6px;
  background: transparent;
  border: 1px solid rgb(var(--color-border));
  cursor: pointer;
  transition: border-color 0.2s;
  display: flex;
  align-items: center;
  justify-content: center;
}

.section-icon-button:hover {
  border-color: rgb(var(--color-foreground));
}

.section-icon-button.selected {
  border-color: rgb(var(--color-foreground));
  border-width: 2px;
  background: rgba(0,0,0,0.03);
}

.section-icon-svg {
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
}

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

.section-icon-label {
  display: none;
}

/* DEPRECATED: Toolbar embedded in accordion headers
#right-main-panel.has-toolbar {
  top: calc(var(--sidebar-header-height) + var(--category-bar-height)) !important;
}
*/

/* ============================================
   FILTER ICON STRIP (Minimalista theme)
   ============================================ */
.filter-icon-strip {
  display: flex;
  align-items: center;
  gap: 18px;
}

.filter-group {
  display: flex;
  gap: 8px;
  padding: 6px 8px;
  border-radius: 0px;
  background: rgba(0, 0, 0, 0.04);
  border: 1px solid rgb(var(--color-border));
}

.filter-group.shape {
  background: transparent;
  border: none;
  padding: 0;
}

/* Category group - same as shape group */
.filter-group.category {
  background: transparent;
  border: none;
  padding: 0;
}

/* Artist card - circular thumbnail */
.collection-card.artist-card .collection-card-visual {
  border-radius: 50%;
  overflow: hidden;
}

.collection-card.artist-card .collection-card-visual img {
  object-fit: cover;
}

.filter-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  padding: 6px;
  background: transparent;
  border: 1px solid rgb(var(--color-border));
  cursor: pointer;
  transition: border-color 0.2s;
}

.filter-icon:hover {
  background: rgba(0, 0, 0, 0.06);
}

.filter-icon.active {
  border-color: rgb(var(--color-foreground));
  background: rgba(0, 0, 0, 0.04);
}

/* Text-mode category filter buttons */
.filter-icon.text-mode {
  min-width: auto;
  max-width: none;
  aspect-ratio: auto;
  padding: 6px 12px;
  font-size: 0.75rem;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: rgba(255, 255, 255, 0.7);
}

.filter-icon.text-mode:hover {
  color: rgba(255, 255, 255, 0.9);
}

.filter-icon.text-mode.active {
  color: #fff;
}

.filter-icon svg {
  width: 100%;
  height: 100%;
  fill: rgb(var(--color-foreground));
  opacity: 0.7;
}

.filter-icon:hover svg {
  opacity: 1;
}

.filter-icon.active svg {
  opacity: 1;
}

.filter-icon.filter-show-all svg {
  stroke: rgb(var(--color-foreground));
}

.filter-icon.filter-show-all.active {
  background: transparent !important;
}
/* ============================================
   SUBCATEGORY ACCORDION
   ============================================ */

.subcategory-accordion {
  flex: 1;
  overflow-y: auto;
  min-height: 0;
  border-top: 1px solid rgba(var(--color-foreground), 0.2);
  scrollbar-gutter: stable;
	padding-bottom: var(--footer-height);
}

/* Using native <details> marker */
.subcategory-item summary {
  cursor: pointer;
}

.subcategory-item {
  border-bottom: 1px solid rgb(var(--color-border));
}

.subcategory-item[open] {
  background: rgba(var(--color-foreground), 0.03);
}

/* .subcategory-item summary {
  list-style: none;
}

.subcategory-item summary::-webkit-details-marker {
  display: none;
} */

.subcategory-header {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 1.25rem .5rem 1.25rem 1.4rem;
  cursor: pointer;
  transition: opacity var(--duration-default, 250ms);
  user-select: none;
}

.subcategory-header-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
}

.subcategory-header-actions {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-shrink: 0;
}

.subcategory-header:hover {
  opacity: 0.7;
}

.subcategory-header:focus-visible {
  outline: none;
  box-shadow: inset 0 0 0 2px rgba(var(--color-foreground), 0.3);
}

.subcategory-label {
  font-family: var(--font-family-base);
  font-size: 14px;
  font-weight: 500;
  color: rgb(var(--color-foreground));
  letter-spacing: -0.02em;
  flex-shrink: 0;
}

.subcategory-toolbar {
  display: flex;
  align-items: center;
  gap: 8px;
}

.subcategory-value {
  font-size: 12px;
  font-weight: 400;
  color: rgb(var(--color-foreground-secondary));
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 100%;
}

.subcategory-toolbar + .subcategory-value {
  margin-left: 0;
}

.subcategory-icon {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
  color: rgb(var(--color-foreground));
  transform: rotate(0deg);
  transition: transform var(--duration-default, 250ms);
}

.subcategory-item[open] > summary .subcategory-icon {
  transform: rotate(180deg);
}

/* Help icon in accordion header */
.accordion-help-icon {
  width: 20px;
  height: 20px;
  padding: 0;
  margin-left: 8px;
  background: transparent;
  border: 1px solid rgb(var(--color-border));
  border-radius: 50%;
  font-size: 11px;
  font-weight: 600;
  color: rgb(var(--color-foreground-secondary));
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: border-color 0.2s, color 0.2s;
}

.accordion-help-icon:hover {
  border-color: rgb(var(--color-foreground));
  color: rgb(var(--color-foreground));
}

/* Single-item variant (auto-open, no caret) */
.subcategory-item--single > .subcategory-header {
  cursor: default;
}

.subcategory-item--single > .subcategory-header:hover {
  opacity: 1;
}

.subcategory-item--single .subcategory-icon {
  display: none;
}

/* Disabled placeholder variant */
.subcategory-item--disabled > .subcategory-header {
  opacity: 0.5;
  pointer-events: none;
  cursor: default;
}

.subcategory-item--disabled .subcategory-value {
  font-style: italic;
}

/* Content area */
.subcategory-content {
  padding: 0 0 24px 0;
}

/* Sticky toolbar inside content */
.subcategory-toolbar--sticky {
  position: sticky;
  top: 0;
  z-index: 1;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 25px 28px 36px;
  background: rgb(var(--color-background));
}

/* ============================================
   ACCORDION TOOLBAR CONTROLS
   ============================================ */

.toolbar-divider {
  width: 1px;
  height: 20px;
  background: rgb(var(--color-border));
}

/* Compact filter icons for accordion header */
.subcategory-toolbar .filter-group {
  display: flex;
  gap: 4px;
  background: transparent;
  border: none;
  padding: 0;
}

.subcategory-toolbar .filter-icon,
.subcategory-toolbar--sticky .filter-icon {
  min-width: 34px;
  height: 34px;
  padding: 6px;
  background: transparent;
  border: 1px solid rgb(var(--color-border));
  border-radius: 4px;
  cursor: pointer;
  transition: border-color var(--duration-default, 250ms);
}

.subcategory-toolbar .filter-icon:hover,
.subcategory-toolbar--sticky .filter-icon:hover {
  border-color: rgb(var(--color-foreground));
}

.subcategory-toolbar .filter-icon.active,
.subcategory-toolbar--sticky .filter-icon.active {
  border-color: rgb(var(--color-foreground));
  background: rgba(var(--color-foreground), 0.05);
}

/* Section selector buttons for accordion header */
.subcategory-toolbar .section-selector,
.subcategory-toolbar--sticky .section-selector {
  display: flex;
  gap: 4px;
}

.subcategory-toolbar .section-button,
.subcategory-toolbar--sticky .section-button {
  min-width: 34px;
  height: 34px;
  padding: 4px;
  background: transparent;
  border: 1px solid rgb(var(--color-border));
  border-radius: 4px;
  cursor: pointer;
  transition: border-color var(--duration-default, 250ms);
}

.subcategory-toolbar .section-button .section-icon-svg,
.subcategory-toolbar--sticky .section-button .section-icon-svg {
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.subcategory-toolbar .section-button .section-icon-svg svg,
.subcategory-toolbar--sticky .section-button .section-icon-svg svg {
  width: 100%;
  height: 100%;
}

.subcategory-toolbar .section-button:hover,
.subcategory-toolbar--sticky .section-button:hover {
  border-color: rgb(var(--color-foreground));
}

.subcategory-toolbar .section-button[aria-pressed="true"],
.subcategory-toolbar--sticky .section-button[aria-pressed="true"] {
  border-color: rgb(var(--color-foreground));
  background: rgba(var(--color-foreground), 0.05);
}

.subcategory-toolbar .section-button:focus-visible {
  outline: none;
  box-shadow: 0 0 0 2px rgba(var(--color-foreground), 0.3);
}

/* Toggle switch for accordion header (Backing) */
.subcategory-toolbar .toggle-switch {
  position: relative;
  display: inline-block;
  width: 36px;
  height: 20px;
}

.subcategory-toolbar .toggle-switch input {
  opacity: 0;
  width: 0;
  height: 0;
}

.subcategory-toolbar .toggle-slider {
  position: absolute;
  cursor: pointer;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: rgb(var(--color-border));
  transition: var(--duration-default, 250ms);
  border-radius: 20px;
}

.subcategory-toolbar .toggle-slider:before {
  position: absolute;
  content: "";
  height: 14px;
  width: 14px;
  left: 3px;
  bottom: 3px;
  background-color: white;
  transition: var(--duration-default, 250ms);
  border-radius: 50%;
}

.subcategory-toolbar input:checked + .toggle-slider {
  background-color: rgb(var(--color-foreground));
}

.subcategory-toolbar input:checked + .toggle-slider:before {
  transform: translateX(16px);
}	

/* ============================================
   HORIZONTAL SCROLL CONTAINER
   ============================================ */

.scroll-container {
  position: relative;
  display: flex;
  align-items: center;
  padding: 0 36px;
}

.horizontal-scroll {
  display: flex;
  gap: 15px;
  overflow-x: auto;
  padding: 4px 0 8px;
  scroll-behavior: smooth;
  scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
  flex: 1;
  min-width: 0;
}

.wood-species-image-grid.horizontal-scroll {
  flex-direction: row;
  flex-wrap: nowrap;
  overflow-x: auto;
  overflow-y: hidden;
}

.horizontal-scroll::-webkit-scrollbar {
  display: none;
}

@media (max-width: 1300px) {
  .horizontal-scroll {
    padding: 0 16px 8px;  /* Tighter padding */
  }
}

/* Scroll arrow buttons */
.scroll-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 28px;
  height: 28px;
  display: none; /* Hidden by default, shown via JS */
  align-items: center;
  justify-content: center;
  background: rgb(var(--color-background));
  border: 1px solid rgb(var(--color-border));
  border-radius: 50%;
  cursor: pointer;
  z-index: 2;
  color: rgb(var(--color-foreground));
  transition: background-color var(--duration-default, 250ms), 
              border-color var(--duration-default, 250ms);
}

.scroll-arrow:hover {
  background: rgb(var(--color-background-input));
  border-color: rgb(var(--color-foreground));
}

.scroll-arrow--left {
  left: 4px;
}

.scroll-arrow--right {
  right: 4px;
}

.scroll-arrow svg {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
}

/* ============================================
   ACCORDION CARD BASE
   ============================================ */

.accordion-card {
  flex-shrink: 0;
  background: rgb(var(--color-background));
  border: 2px solid rgb(var(--color-border));
  border-radius: 4px;
  cursor: pointer;
  transition: border-color var(--duration-default, 250ms);
}

.accordion-card:hover:not(.selected) {
  border-color: rgba(var(--color-foreground), 0.4);
}

.accordion-card.selected {
  border-color: rgb(var(--color-foreground));
}

.accordion-card:focus-visible {
  outline: none;
  box-shadow: 0 0 0 2px rgba(var(--color-foreground), 0.3);
}

/* ============================================
   STYLE CARDS (Archetypes) - 140px
   ============================================ */

.style-card {
  width: 140px;
}

.style-card-image {
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  border-radius: 2px 2px 0 0;
  display: block;
}

.style-card-label {
  padding: 8px;
  font-size: 11px;
  font-weight: 500;
  text-align: center;
  color: rgb(var(--color-foreground));
  border-top: 1px solid rgb(var(--color-border));
}

/* ============================================
SPECIES CARDS - 140px
   ============================================ */

.accordion-species-card {
  width: 140px;
  padding: 4px;
}

.accordion-species-card .species-card-label {
  font-size: 12px;
  font-weight: 500;
  color: rgb(var(--color-foreground));
  margin-bottom: 0px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.accordion-species-card .species-grain-grid {
  display: grid; /* Changed from flex */
  grid-template-columns: repeat(2, 1fr); /* Add this line */
  gap: 2px;
}

.accordion-species-card .grain-thumb {
  width: 100%;       /* Changed from fixed px */
  height: auto;      /* Changed from fixed px */
  aspect-ratio: 1/1; /* Keeps them square */
  border: 2px solid rgb(var(--color-border));
  border-radius: 4px;
  overflow: hidden;
  cursor: pointer;
  transition: border-color var(--duration-default, 250ms);
}

.accordion-species-card .grain-thumb:hover:not(.selected) {
  border-color: rgba(var(--color-foreground), 0.4);
}

.accordion-species-card .grain-thumb.selected {
  border-color: rgb(var(--color-foreground));
}

.accordion-species-card .grain-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* ============================================
   BACKING PANEL HORIZONTAL MODE
   ============================================ */

.backing-panel-horizontal {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.backing-content-wrapper {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.backing-row-label {
  font-size: 12px;
  font-weight: 500;
  color: rgb(var(--color-foreground));
  text-transform: uppercase;
  letter-spacing: 0.05em;
  padding: 0 25px;
}

.backing-material-card {
  width: 100px;
}

.backing-material-swatch {
  width: 100%;
  aspect-ratio: 1 / 1;
  border-radius: 2px 2px 0 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: rgb(var(--color-background));
}

.backing-material-swatch .none-icon {
  width: 24px;
  height: 24px;
  color: rgb(var(--color-foreground-secondary));
}

.backing-material-fill {
  width: 100%;
  height: 100%;
}

/* ============================================
   BACKING MATERIAL CARDS - 56px
   ============================================ */

/* .backing-card {
  width: 56px;
}

.backing-card-swatch {
  width: 100%;
  aspect-ratio: 1 / 1;
  border-radius: 2px 2px 0 0;
}

.backing-card-label {
  padding: 6px 4px;
  font-size: 10px;
  font-weight: 500;
  text-align: center;
  color: rgb(var(--color-foreground));
  border-top: 1px solid rgb(var(--color-border));
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
} */

/* ============================================
   PAINT COLOR CARDS - 56px
   ============================================ */

.paint-card {
  width: 100px;
}

.paint-card-swatch {
  width: 100%;
  aspect-ratio: 1 / 1;
  border-radius: 2px 2px 0 0;
}

.paint-card-label {
  padding: 4px 0;
  font-size: 9px;
  font-weight: 500;
  text-align: center;
  color: rgb(var(--color-foreground));
  border-top: 1px solid rgb(var(--color-border));
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* ============================================
   ACCENT WALL CARDS - 88px
   ============================================ */

.accent-card {
  width: 88px;
}

.accent-card-image {
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  border-radius: 2px 2px 0 0;
  display: block;
}

.accent-card-label {
  padding: 6px 4px;
  font-size: 10px;
  font-weight: 500;
  text-align: center;
  color: rgb(var(--color-foreground));
  border-top: 1px solid rgb(var(--color-border));
}

/* ============================================
   ROOM SCENE CARDS - 140px
   ============================================ */

.room-card {
  width: 140px;
}

.room-card-image {
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  border-radius: 2px 2px 0 0;
  display: block;
}

.room-card-label {
  padding: 8px;
  font-size: 11px;
  font-weight: 500;
  text-align: center;
  color: rgb(var(--color-foreground));
}

/* ============================================
   SLIDER CARD (Layout subcategory)
   ============================================ */

.slider-card {
  margin: 0 25px;
  padding: 16px;
  background: rgba(var(--color-foreground), 0.02);
  border: 1px solid rgb(var(--color-border));
  border-radius: 4px;
}

/* ============================================
   ASYMMETRIC TOGGLE (Layout > Asymmetric)
   ============================================ */

.asymmetric-toggle-card {
  margin: 16px 25px 0;
  padding: 16px;
  background: rgba(var(--color-foreground), 0.02);
  border: 1px solid rgb(var(--color-border));
  border-radius: 4px;
}

.asymmetric-toggle-label {
  font-size: 12px;
  font-weight: 500;
  color: rgb(var(--color-foreground-secondary));
  margin-bottom: 12px;
}

.asymmetric-toggle-group {
  display: flex;
  gap: 8px;
}

.asymmetric-toggle-btn {
  flex: 1;
  padding: 10px 16px;
  font-size: 13px;
  font-weight: 500;
  color: rgb(var(--color-foreground-secondary));
  background: transparent;
  border: 1px solid rgb(var(--color-border));
  border-radius: 4px;
  cursor: pointer;
  transition: all 150ms ease;
}

.asymmetric-toggle-btn:hover {
  color: rgb(var(--color-foreground));
  border-color: rgb(var(--color-foreground-secondary));
}

.asymmetric-toggle-btn.active {
  color: rgb(var(--color-foreground));
  background: rgba(var(--color-foreground), 0.08);
  border-color: rgb(var(--color-foreground));
}

/* ============================================
   UPLOAD CARD (AUDIO > Custom)
   Matches .slider-card + .slider-group pattern
   ============================================ */

.upload-card {
  margin: 0 25px;
  padding: 24px 60px;
  background: rgba(var(--color-foreground), 0.02);
  border: 1px solid rgb(var(--color-border));
  border-radius: 4px;
  cursor: pointer;
  transition: border-color 250ms ease;
}

.upload-card:hover,
.upload-card.drag-over {
  border-color: rgb(var(--color-foreground));
}

/* Inner content - matches .slider-group padding */
.upload-card-content {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  padding: 14px;
}

.upload-card-icon {
  color: rgb(var(--color-foreground-secondary));
  transition: color 250ms ease;
}

.upload-card:hover .upload-card-icon,
.upload-card.drag-over .upload-card-icon {
  color: rgb(var(--color-foreground));
}

.upload-card-title {
  font-size: 14px;
  font-weight: 500;
  color: rgb(var(--color-foreground));
}

.upload-card-hint {
  font-size: 12px;
  color: rgb(var(--color-foreground-secondary));
}

.upload-card-button {
  font-family: var(--font-family-base);
  font-weight: 600;
  font-size: 13px;
  letter-spacing: -0.02em;
  padding: 10px 20px;
  background-color: transparent;
  color: rgb(var(--color-foreground));
  border: 1px solid rgb(var(--color-border));
  border-radius: 4px;
  cursor: pointer;
  transition: border-color 250ms ease;
}

.upload-card-button:hover {
  border-color: rgb(var(--color-foreground));
}

.upload-card-formats {
  font-size: 11px;
  color: rgb(var(--color-foreground-secondary));
}

/* ============================================
   TOUR CARD (AUDIO > Tour)
   Matches .slider-card / .upload-card pattern
   ============================================ */

.tour-card {
  margin: 0 25px;
  padding: 16px;
  background: rgba(var(--color-foreground), 0.02);
  border: 1px solid rgb(var(--color-border));
  border-radius: 4px;
}

.tour-card-content {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  padding: 14px;
}

.tour-card-title {
  font-size: 14px;
  font-weight: 500;
  color: rgb(var(--color-foreground));
}

.tour-card-description {
  font-size: 12px;
  color: rgb(var(--color-foreground-secondary));
  text-align: center;
  max-width: 280px;
  line-height: 1.5;
}

.tour-card-button {
  font-family: var(--font-family-base);
  font-weight: 600;
  font-size: 13px;
  letter-spacing: -0.02em;
  padding: 10px 20px;
  background-color: rgb(var(--color-foreground));
  color: rgb(var(--color-background));
  border: 1px solid rgb(var(--color-foreground));
  border-radius: 4px;
  cursor: pointer;
  transition: background-color 250ms ease, border-color 250ms ease;
}

.tour-card-button:hover {
  background-color: #353535;
  border-color: #353535;
}

/* ============================================
   AUDIO SLICER PANEL - Minimalista Theme
   "Pick a Moment" component styles
   ============================================ */

.audio-slicer-panel {
  display: contents;
}

.audio-slicer-upload-section,
.audio-slicer-trimmer-section,
.audio-slicer-enhance-section {
  display: block;
	margin: 0 25px;
}

.upload-icon {
  margin-bottom: 12px;
  color: rgb(var(--color-foreground-secondary));
}

.upload-icon svg {
  width: 40px;
  height: 40px;
}

.slicer-time-separator {
  color: rgb(var(--color-foreground-secondary));
}

/* ============================================
   DROP ZONE
   ============================================ */

.slicer-drop-zone {
  border: 1px dashed rgb(var(--color-border));
  border-radius: 4px;
  padding: 0;
  text-align: center;
  cursor: pointer;
  transition: border-color 250ms ease, background-color 250ms ease;
}

.slicer-drop-zone:hover,
.slicer-drop-zone.dragover {
  border-color: rgb(var(--color-foreground));
  background-color: rgba(var(--color-foreground), 0.02);
}

.slicer-drop-content.hidden {
  display: none;
}

.slicer-drop-zone.hidden {
  display: none;
}

.slicer-drop-zone input {
  display: none;
}

.slicer-drop-text {
  font-family: var(--font-body-family);
  font-size: 14px;
  font-weight: 400;
  color: rgb(var(--color-foreground));
  margin: 0 0 4px;
}

.slicer-drop-hint {
  font-family: var(--font-body-family);
  font-size: 12px;
  color: rgb(var(--color-foreground-secondary));
  margin: 0;
}

/* ============================================
   WAVEFORM
   ============================================ */

.slicer-waveform-wrap {
  position: relative;
  flex: 1;
  min-width: 0;
  background: rgb(var(--color-background-secondary));
  border-radius: 4px;
  overflow: hidden;
}

.slicer-waveform {
  width: 100%;
  height: 64px;
  display: block;
}

.slicer-playhead {
  position: absolute;
  top: 0;
  left: 0;
  width: 2px;
  height: 64px;
  background: rgb(var(--color-foreground));
  pointer-events: none;
  display: none;
  transition: left 50ms linear;
}

.slicer-playhead.visible {
  display: block;
}

.slicer-selection {
  position: absolute;
  top: 0;
  height: 64px;
  background: rgba(var(--color-foreground), 0.1);
  border-left: 3px solid rgb(76, 175, 80);
  border-right: 3px solid rgb(239, 83, 80);
  pointer-events: none;
  display: none;
}

.slicer-handle {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 12px;
  height: 32px;
  background: rgb(var(--color-background));
  border: 2px solid;
  border-radius: 3px;
  cursor: ew-resize;
  pointer-events: auto;
  z-index: 2;
}
.slicer-handle::after {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 2px;
  height: 12px;
  background: currentColor;
  opacity: 0.5;
}
.slicer-handle-start {
  left: -8px;
  border-color: rgb(76, 175, 80);
  color: rgb(76, 175, 80);
}
.slicer-handle-end {
  right: -8px;
  border-color: rgb(239, 83, 80);
  color: rgb(239, 83, 80);
}

.slicer-selection.visible {
  display: block;
}

/* ============================================
   TRANSPORT CONTROLS
   ============================================ */

.slicer-transport {
  /*display: flex;*/
	display: none !important;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 12px;
}

.slicer-time {
  font-family: var(--font-body-family);
  font-size: 12px;
  font-weight: 400;
  color: rgb(var(--color-foreground-secondary));
  min-width: 36px;
  background: transparent;
  border: none;
  border-bottom: 1px solid transparent;
  padding: 2px 0;
  outline: none;
  cursor: text;
}

.slicer-time:hover {
  border-bottom-color: rgb(var(--color-border));
}

.slicer-time:focus {
  border-bottom-color: rgb(var(--color-foreground));
  color: rgb(var(--color-foreground));
}

.slicer-time-start {
  text-align: right;
}

.slicer-time-end {
  text-align: left;
}

/* Commit button */
.slicer-commit-row {
  margin-bottom: 12px;
}

.slicer-btn-commit {
  width: 100%;
  padding: 14px 16px;
  border: 1px solid rgb(var(--color-foreground));
  border-radius: 4px;
  background: rgb(var(--color-button));
  color: rgb(var(--color-button-text));
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  transition: background-color 250ms ease;
}

.slicer-btn-commit:hover:not(:disabled) {
  background: rgb(var(--color-button-hover));
}

.slicer-btn-commit:disabled {
  opacity: 0.4;
  cursor: not-allowed;
}

/* ============================================
   AUDIO SLICER V2 - Grandma-Friendly Redesign
   ============================================ */

/* Song loaded state */
.slicer-song-loaded {
  display: none;
  align-items: center;
  gap: 16px;
  padding: 16px 12px 16px 14px;
  background: rgba(var(--color-foreground), 0.03);
  border: 1px solid rgb(var(--color-border));
}

.slicer-song-loaded.visible {
  display: flex;
}

.slicer-song-artwork {
  width: 24px;
  height: 24px;
  background: rgb(var(--color-foreground));
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.slicer-song-artwork svg {
  width: 16px;
  height: 16px;
  color: rgb(var(--color-background));
}

.slicer-song-info {
  flex: 1;
  min-width: 0;
}

.slicer-song-name {
  font-size: 14px;
  font-weight: 500;
  color: rgb(var(--color-foreground));
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.slicer-song-duration {
  font-size: 12px;
  color: rgb(var(--color-foreground-secondary));
}

.slicer-song-change {
  font-size: 12px;
  font-weight: 500;
  color: rgb(var(--color-foreground));
  text-decoration: underline;
  text-underline-offset: 3px;
  cursor: pointer;
  background: none;
  border: none;
  padding: 0;
}

/* Instructions banner */
.slicer-instructions {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 14px;
  background: rgba(var(--color-foreground), 0.03);
  border: 1px solid rgb(var(--color-border));
  margin-bottom: 16px;
}

.slicer-instructions-number {
  width: 22px;
  height: 22px;
  background: rgb(var(--color-foreground));
  color: rgb(var(--color-background));
  border-radius: 50%;
  font-size: 11px;
  font-weight: 600;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.slicer-instructions-text {
  font-size: 13px;
  color: rgb(var(--color-foreground));
}

/* Section header (numbered sections) */
.slicer-card {
  background: rgba(var(--color-foreground), 0.03);
  border: 1px solid rgb(var(--color-border));
  margin-bottom: 28px;
}

.slicer-card .slicer-section-header {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 12px 14px;
  background: none;
  border: none;
  margin-bottom: 0;
}

.slicer-section-header {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 4px 12px 12px;
  background: rgba(var(--color-foreground), 0.03);
  border: 1px solid rgb(var(--color-border));
  margin-bottom: 28px;
}

.slicer-intent-controls {
  display: flex;
  gap: 24px;
  padding: 0 14px 14px 48px;
}

.slicer-drop-zone.slicer-card {
  text-align: left;
  padding: 0;
  border-style: solid;
}

.slicer-drop-zone.slicer-card .slicer-section-header {
  padding: 12px 14px;
  justify-content: flex-start;
}

.slicer-drop-content {
  text-align: center;
  padding: 24px 16px;
}

.slicer-section-header:last-of-type {
  margin-bottom: 16px;
}

.slicer-section-number {
  width: 22px;
  height: 22px;
  background: rgb(var(--color-foreground));
  color: rgb(var(--color-background));
  border-radius: 50%;
  font-size: 11px;
  font-weight: 600;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.slicer-section-text {
  flex: 1;
}

.slicer-section-title {
  font-size: 13px;
  font-weight: 600;
  color: rgb(var(--color-foreground));
}

.slicer-section-desc {
  font-size: 12px;
  color: rgb(var(--color-foreground-secondary));
  margin-top: 2px;
}

/* Controls row (play, start, end, reset) */
.slicer-controls-row {
  display: flex;
  align-items: stretch;
  gap: 8px;
  margin: 28px 0;
}

.slicer-controls-row .slicer-play-btn {
  width: 44px;
  height: auto;
  min-height: 44px;
  margin: 0;
  padding: 0;
  flex-shrink: 0;
}

.slicer-controls-row .slicer-mark-btn {
  flex: 1;
  flex-direction: row;
  gap: 8px;
  padding: 10px;
}

.slicer-controls-row .slicer-mark-btn-label {
  font-size: 11px;
}

.slicer-controls-row .slicer-mark-btn-time {
  font-size: 11px;
}

.slicer-btn-reset {
  padding: 10px;
  background: transparent;
  border: 1px solid rgb(var(--color-border));
  border-radius: 4px;
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: rgb(var(--color-foreground-secondary));
  cursor: pointer;
  transition: border-color 250ms, color 250ms;
  flex-shrink: 0;
}

.slicer-btn-reset:hover {
  border-color: rgb(var(--color-foreground));
  color: rgb(var(--color-foreground));
}

/* Waveform with skip buttons */
.slicer-waveform-row {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 12px;
}

.slicer-skip-btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 60px;
  background: transparent;
  border: 1px solid rgb(var(--color-border));
  border-radius: 4px;
  cursor: pointer;
  color: rgb(var(--color-foreground));
  flex-shrink: 0;
  transition: border-color 250ms;
}

.slicer-skip-btn:hover {
  border-color: rgb(var(--color-foreground));
}

.slicer-skip-btn svg {
  width: 18px;
  height: 18px;
}

.slicer-skip-btn span {
  font-size: 10px;
  font-weight: 500;
  margin-top: 2px;
}

/* Full-width play button */
.slicer-play-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: 100%;
  height: 44px;
  margin: 14px 0;
  background: rgb(var(--color-foreground));
  border: none;
  border-radius: 4px;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: rgb(var(--color-background));
  cursor: pointer;
  transition: background-color 250ms;
}

.slicer-play-btn:hover {
  background: rgb(var(--color-foreground-secondary));
}

.slicer-play-btn svg {
  width: 16px;
  height: 16px;
}

.slicer-play-btn.playing {
  background: rgb(var(--color-foreground-secondary));
}

/* Mark buttons v2 */
.slicer-mark-buttons {
  display: flex;
  gap: 10px;
  margin-bottom: 14px;
}

.slicer-mark-btn {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 4px;
  padding: 14px 10px;
  background: transparent;
  border: 1px solid rgb(var(--color-border));
  border-radius: 4px;
  cursor: pointer;
  transition: border-color 250ms;
}

.slicer-mark-btn:hover {
  border-color: rgb(var(--color-foreground));
}

.slicer-mark-btn.marked {
  border-color: rgb(var(--color-foreground));
  border-width: 2px;
}

.slicer-btn-mark-start {
  border-color: rgba(76, 175, 80, 0.4);
}
.slicer-btn-mark-start:hover {
  border-color: rgba(76, 175, 80, 0.7);
  background: rgba(76, 175, 80, 0.05);
}
.slicer-btn-mark-start.marked {
  border-color: rgb(76, 175, 80);
  background: rgba(76, 175, 80, 0.08);
}

.slicer-btn-mark-end {
  border-color: rgba(239, 83, 80, 0.4);
}
.slicer-btn-mark-end:hover {
  border-color: rgba(239, 83, 80, 0.7);
  background: rgba(239, 83, 80, 0.05);
}
.slicer-btn-mark-end.marked {
  border-color: rgb(239, 83, 80);
  background: rgba(239, 83, 80, 0.08);
}

.slicer-mark-btn svg {
  width: 20px;
  height: 20px;
  color: rgb(var(--color-foreground-secondary));
}

.slicer-mark-btn.marked svg {
  color: rgb(var(--color-foreground));
}

.slicer-mark-btn-label {
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: rgb(var(--color-foreground));
}

.slicer-mark-btn-time {
  font-size: 11px;
  font-weight: 500;
  color: rgb(var(--color-foreground-secondary));
  background: transparent;
  border: none;
  border-bottom: 1px solid transparent;
  text-align: center;
  width: 42px;
  padding: 2px 0;
  outline: none;
  cursor: pointer;
}

.slicer-mark-btn-time:not([readonly]) {
  border-bottom-color: rgb(var(--color-border));
  cursor: text;
}

.slicer-mark-btn-time:focus {
  border-bottom-color: rgb(var(--color-foreground));
}

.slicer-mark-btn-time::placeholder {
  color: rgb(var(--color-foreground-secondary));
}

.slicer-mark-btn.marked .slicer-mark-btn-time {
  color: rgb(var(--color-foreground));
}

/* Selection summary */
.slicer-selection-summary {
  display: none;
  align-items: center;
  gap: 12px;
  padding: 12px 14px;
  background: rgba(var(--color-foreground), 0.03);
  border: 2px solid rgb(var(--color-foreground));
  margin-bottom: 10px;
}

.slicer-selection-summary.visible {
  display: flex;
}

.slicer-summary-icon {
  width: 28px;
  height: 28px;
  background: rgb(var(--color-foreground));
  color: rgb(var(--color-background));
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  flex-shrink: 0;
}

.slicer-summary-text {
  flex: 1;
  font-size: 13px;
}

.slicer-summary-range {
  display: block;
  font-size: 14px;
  font-weight: 500;
  color: rgb(var(--color-foreground));
}

.slicer-summary-duration {
  color: rgb(var(--color-foreground-secondary));
}

.slicer-summary-preview {
  display: flex;
  align-items: center;
  gap: 5px;
  padding: 8px 12px;
  background: rgb(var(--color-foreground));
  border: none;
  border-radius: 4px;
  font-size: 11px;
  font-weight: 600;
  color: rgb(var(--color-background));
  cursor: pointer;
}

.slicer-summary-preview svg {
  width: 12px;
  height: 12px;
}

/* Use full song link */
.slicer-use-full {
  display: block;
  width: 100%;
  padding: 10px;
  background: transparent;
  border: none;
  font-size: 12px;
  color: rgb(var(--color-foreground-secondary));
  cursor: pointer;
  text-align: center;
}

.slicer-use-full span {
  text-decoration: underline;
  text-underline-offset: 3px;
}

.slicer-use-full:hover span {
  color: rgb(var(--color-foreground));
}

.slicer-vocals-preview {
  display: none;
  align-items: center;
  gap: 12px;
  padding: 12px 16px;
  background: rgb(var(--color-background-secondary));
  border-radius: 8px;
  margin-top: -8px;
  margin-bottom: 16px;
}

.slicer-vocals-preview.visible {
  display: flex;
}

.slicer-btn-vocals-preview {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 16px;
  background: rgb(var(--color-foreground));
  color: rgb(var(--color-background));
  border: none;
  border-radius: 6px;
  font-size: 14px;
  cursor: pointer;
}

.slicer-btn-vocals-preview:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.slicer-btn-vocals-preview svg {
  width: 16px;
  height: 16px;
}

.slicer-vocals-status {
  font-size: 12px;
  color: rgb(var(--color-foreground-secondary));
}

/* Toggle cards */
.slicer-toggle-card {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 14px;
  padding: 14px;
  background: rgba(var(--color-foreground), 0.03);
  border: 1px solid rgb(var(--color-border));
  margin-bottom: 10px;
  transition: border-color 250ms;
}

.slicer-toggle-card.active {
  border-color: rgb(var(--color-foreground));
  border-width: 2px;
}

.slicer-toggle-icon {
  width: 40px;
  height: 40px;
  background: rgb(var(--color-background));
  border: 1px solid rgb(var(--color-border));
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: background-color 250ms, border-color 250ms;
}

.slicer-toggle-card.active .slicer-toggle-icon {
  background: rgb(var(--color-foreground));
  border-color: rgb(var(--color-foreground));
}

.slicer-toggle-icon svg {
  width: 20px;
  height: 20px;
  color: rgb(var(--color-foreground-secondary));
}

.slicer-toggle-card.active .slicer-toggle-icon svg {
  color: rgb(var(--color-background));
}

.slicer-toggle-text {
  flex: 1;
  min-width: 120px;
}

.slicer-toggle-title {
  font-size: 14px;
  font-weight: 500;
  color: rgb(var(--color-foreground));
  margin-bottom: 2px;
}

.slicer-toggle-desc {
  font-size: 11px;
  color: rgb(var(--color-foreground-secondary));
}

/* Toggle previews row */
.slicer-toggle-previews {
  width: 100%;
  display: none;
  gap: 8px;
  padding-top: 12px;
  border-top: 1px solid rgb(var(--color-border));
}

.slicer-toggle-card.active .slicer-toggle-previews {
  display: flex;
}

.slicer-toggle-preview-btn {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
  padding: 8px 12px;
  background: rgb(var(--color-background));
  border: 1px solid rgb(var(--color-border));
  border-radius: 4px;
  font-size: 11px;
  font-weight: 500;
  color: rgb(var(--color-foreground));
  cursor: pointer;
  transition: border-color 250ms;
}

.slicer-toggle-preview-btn:hover {
  border-color: rgb(var(--color-foreground));
}

.slicer-toggle-preview-btn svg {
  width: 12px;
  height: 12px;
}

/* Optimization Section */
.slicer-optimize-section {
  margin-top: 16px;
  padding-top: 16px;
  border-top: 1px solid rgba(255,255,255,0.1);
}

.slicer-optimize-controls {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 8px 0;
}

.slicer-radio {
  display: flex;
  align-items: center;
  gap: 4px;
  font-size: 13px;
  cursor: pointer;
}

.slicer-btn-optimize {
  background: var(--accent-gold, #D9A464);
  color: #1a1a1a;
  border: none;
  padding: 6px 14px;
  border-radius: 4px;
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
}

.slicer-btn-optimize:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.slicer-optimize-status {
  font-size: 12px;
  margin-left: auto;
}

.slicer-optimize-status.optimized { color: #27ae60; }
.slicer-optimize-status.fallback { color: #f39c12; }
.slicer-optimize-status.error { color: #e74c3c; }

/* CTA Footer */
.slicer-cta-footer {
  display: flex;
  gap: 12px;
  margin-top: 20px;
  padding-top: 20px;
  border-top: 1px solid rgb(var(--color-border));
}

.slicer-cta-footer .slicer-btn-secondary,
.slicer-cta-footer .slicer-btn-primary {
  flex: 1;
  height: 36px;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  border-radius: 4px;
  cursor: pointer;
  transition: background-color 250ms, border-color 250ms;
}

.slicer-cta-footer .slicer-btn-secondary {
  background: transparent;
  border: 1px solid rgb(var(--color-border));
  color: rgb(var(--color-foreground));
}

.slicer-cta-footer .slicer-btn-secondary:hover:not(:disabled) {
  border-color: rgb(var(--color-foreground));
}

.slicer-cta-footer .slicer-btn-secondary:disabled {
  opacity: 0.4;
  cursor: not-allowed;
}

.slicer-cta-footer .slicer-btn-primary {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  background: rgb(var(--color-foreground));
  border: none;
  color: rgb(var(--color-background));
}

.slicer-cta-footer .slicer-btn-primary:disabled {
  background: rgb(var(--color-border));
  color: rgb(var(--color-foreground-secondary));
  cursor: not-allowed;
  opacity: 0.6;
}

.slicer-cta-footer .slicer-btn-primary:hover {
  background: rgb(var(--color-foreground-secondary));
}

.slicer-cta-footer .slicer-btn-primary svg {
  width: 14px;
  height: 14px;
}

/* ============================================
   CANVAS CONTROLS (Zoom, Reset, Fullscreen)
   Only visible for Blank Wall room
   ============================================ */

.bottom-controls {
  position: absolute !important;
  bottom: 32px;
  left: 16px;
  z-index: 100;
  
  display: none; /* Hidden by default */
  flex-direction: column;
  gap: 8px;
  padding: 8px;
  
  background: rgb(var(--color-background));
  border: 1px solid rgb(var(--color-border));
  border-radius: 8px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
  
  pointer-events: auto;
}

/* Show only when blank wall is active */
body.room-blank-wall .bottom-controls {
  display: flex;
}

.control-button {
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  
  background: rgb(var(--color-background));
  border: 1px solid rgb(var(--color-border));
  border-radius: 50%;
  color: rgb(var(--color-foreground));
  
  cursor: pointer;
  transition: background-color var(--duration-default, 250ms),
              border-color var(--duration-default, 250ms);
  
  font-size: 16px;
  font-weight: 500;
}

.control-button:hover {
  background: rgb(var(--color-background-input));
  border-color: rgb(var(--color-foreground));
}

.control-button:active {
  transform: scale(0.95);
}

/* Hide panels when menus-hidden class is on body */
body.menus-hidden .panel,
body.menus-hidden .sidebar {
  opacity: 0;
  pointer-events: none;
}

body.menus-hidden .bottom-controls {
  display: flex; /* Override hidden when menus hidden but blank wall */
}

body.menus-hidden:not(.room-blank-wall) .bottom-controls {
  display: none;
}

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

.collection-card {
  width: 160px;
  display: flex;
  flex-direction: column;
}

.collection-card-visual {
  width: 100%;
  height: 80px;
  background: linear-gradient(135deg, rgba(var(--color-foreground), 0.05), rgba(var(--color-foreground), 0.1));
  border-radius: 2px 2px 0 0;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}

.collection-card-visual img {
  width: 100%;
  height: 100%;
  object-fit: contain;
	padding: 8px;
}

.collection-card-icon {
  font-size: 32px;
  opacity: 0.6;
}

.collection-card-info {
  padding: 8px;
  border-top: 1px solid rgb(var(--color-border));
}

.collection-card-title {
  font-size: 12px;
  font-weight: 500;
  color: rgb(var(--color-foreground));
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.collection-card-meta {
  font-size: 10px;
  color: rgba(var(--color-foreground), 0.6);
  margin-top: 2px;
}

/* ============================================
   VARIANT SELECTOR
   ============================================ */

.collection-variant-area {
  margin: 18px 25px 0 25px;
  padding: 12px 16px 12px 12px;
  background: rgba(var(--color-foreground), 0.03);
  border-radius: 4px;
  min-height: 44px;
}

.collection-variant-selector {
  display: flex;
  align-items: center;
  gap: 12px;
}

.variant-selector-label {
  font-size: 11px;
  color: rgba(var(--color-foreground), 0.6);
  text-transform: lowercase;
}

.variant-chip-container {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.variant-chip {
  padding: 6px 12px;
  font-size: 12px;
  background: transparent;
  border: 1px solid rgb(var(--color-border));
  border-radius: 16px;
  color: rgb(var(--color-foreground));
  cursor: pointer;
  transition: all var(--duration-default, 250ms);
}

.variant-chip:hover:not(.selected) {
  border-color: rgba(var(--color-foreground), 0.4);
}

.variant-chip.selected {
  background: rgb(var(--color-foreground));
  color: rgb(var(--color-background));
  border-color: rgb(var(--color-foreground));
}

.variant-selector-empty {
  font-size: 12px;
  color: rgba(var(--color-foreground), 0.4);
  font-style: italic;
}

/* Demucs confirmation modal */
.demucs-confirm-overlay {
  position: fixed; top: 0; left: 0; right: 0; bottom: 0;
  background: rgba(0,0,0,0.6); display: flex; align-items: center; justify-content: center; z-index: 10000;
}
.demucs-confirm-modal {
  background: #fff; border-radius: 8px; padding: 24px 32px; max-width: 320px; text-align: center;
}
.demucs-confirm-title { font-size: 18px; font-weight: 600; margin-bottom: 12px; }
.demucs-confirm-modal p { margin: 0 0 8px; color: #666; font-size: 14px; }
.demucs-confirm-estimate { font-size: 28px; font-weight: 700; color: #2c3e50; margin-bottom: 20px; }
.demucs-confirm-buttons { display: flex; gap: 12px; justify-content: center; }
.demucs-btn-cancel, .demucs-btn-continue {
  padding: 10px 24px; border-radius: 4px; font-size: 14px; cursor: pointer; border: none;
}
.demucs-btn-cancel { background: #e0e0e0; color: #333; }
.demucs-btn-continue { background: #3498db; color: #fff; }