/**
 * swipe-answer.css
 * Last modified: v016.200 (2025-11-29)
 * Changes: Replace hardcoded rgba colors with theme variables
 */

/* ============================================
   Swipe Answer Container
   ============================================ */

.swipe-answer-container {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  padding: 1rem 0;
}

/* ============================================
   Experience Selection (Bottom)
   Uses slider-track styling from two-row-scale.css
   ============================================ */

.swipe-experience-section {
  position: relative; /* For absolute positioning of desire menu */
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.5rem;
  padding: 0 1rem;
}

/* Track - copy from two-row-scale.css but for swipe-experience-track */
.swipe-experience-track {
  position: relative;
  display: flex;
  justify-content: center;
  gap: 0.5rem;
  margin-bottom: 0.5rem;
}

/* Individual option - 25% larger overall */
.swipe-experience-track .slider-option {
  flex: 1.25; /* 25% larger flex basis */
  min-width: 0;
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  cursor: pointer;
  transition: all 0.2s;
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  touch-action: manipulation;
  padding: 0.5rem; /* Add padding for larger clickable area */
}

/* Hide actual radio input */
.swipe-experience-track .slider-option input {
  display: none;
}

/* Icon/Emoji - start at full brightness, 25% larger */
.swipe-experience-track .slider-icon {
  font-size: 2.5rem; /* 25% larger than 2rem */
  line-height: 1;
  min-height: 2.5rem;
  max-height: 2.5rem;
  margin-bottom: 0.5rem;
  transition: all 0.2s;
  filter: brightness(1) opacity(1);
  user-select: none;
  -webkit-user-select: none;
  pointer-events: none;
  display: inline-block;
  text-align: center;
}

.swipe-experience-track .slider-option:hover .slider-icon {
  transform: scale(1.1);
}

.swipe-experience-track .slider-option input:checked ~ .slider-icon {
  filter: brightness(1) opacity(1);
  transform: scale(1.15);
}

/* Dim unselected emojis when one is selected */
.swipe-experience-track:has(input:checked) .slider-option:not(:has(input:checked)) .slider-icon {
  filter: brightness(0.6) opacity(0.7);
}

/* SVG Icon specific styles for experience track */
.swipe-experience-track .slider-icon.slider-icon-svg {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  color: var(--theme-scale-label-dim, rgba(180, 180, 180, 0.7));
  filter: none;
}

.swipe-experience-track .slider-icon-svg svg {
  width: 2rem;
  height: 2rem;
}

.swipe-experience-track .slider-option:hover .slider-icon-svg {
  color: var(--theme-scale-label-hover, rgba(200, 200, 200, 0.9));
  transform: scale(1.1);
}

.swipe-experience-track .slider-option input:checked ~ .slider-icon-svg {
  color: var(--option-color, #4f46e5);
  filter: drop-shadow(0 0 8px var(--option-color, #4f46e5));
  transform: scale(1.15);
}

/* Dim unselected SVG icons when one is selected */
.swipe-experience-track:has(input:checked) .slider-option:not(:has(input:checked)) .slider-icon-svg {
  color: var(--theme-text-muted, rgba(120, 120, 120, 0.5));
}

/* === COLORED ICONS MODE for Experience Track === */
body.colored-icons .swipe-experience-track .slider-icon-svg {
  color: var(--option-color, #4f46e5);
  opacity: 0.55;
  filter: saturate(0.8);
}

body.colored-icons .swipe-experience-track .slider-option:hover .slider-icon-svg {
  color: var(--option-color, #4f46e5);
  opacity: 0.7;
  filter: saturate(0.9);
  transform: scale(1.1);
}

body.colored-icons .swipe-experience-track .slider-option input:checked ~ .slider-icon-svg {
  color: var(--option-color, #4f46e5);
  opacity: 1;
  filter: drop-shadow(0 0 8px var(--option-color, #4f46e5)) saturate(1);
  transform: scale(1.15);
}

body.colored-icons .swipe-experience-track:has(input:checked) .slider-option:not(:has(input:checked)) .slider-icon-svg {
  color: var(--option-color, #4f46e5);
  opacity: 0.35;
  filter: saturate(0.6);
}

/* Background bar under icon - gray by default */
.swipe-experience-track .slider-bg {
  width: 100%;
  height: 8px;
  min-height: 8px;
  max-height: 8px;
  background: var(--theme-scale-bar-bg, rgba(128, 128, 128, 0.3));
  border-radius: 4px;
  position: relative;
  transition: all 0.2s;
  box-sizing: border-box;
}

.swipe-experience-track .slider-option:hover .slider-bg {
  background: var(--theme-scale-bar-hover, rgba(128, 128, 128, 0.5));
}

.swipe-experience-track .slider-option input:checked ~ .slider-bg {
  background: var(--option-color, #4f46e5);
  box-shadow: 0 0 12px var(--option-color, #4f46e5);
  /* Add outline when selected */
  outline: 3px solid var(--option-color);
  outline-offset: -3px;
}

/* Label text under bar - also 25% larger */
.swipe-experience-track .slider-label-text {
  font-size: 0.9375rem; /* 25% larger than 0.75rem */
  color: var(--theme-scale-label-dim, rgba(255, 255, 255, 0.7));
  margin-top: 0.25rem;
  text-align: center;
  transition: color 0.2s;
  user-select: none;
  -webkit-user-select: none;
  pointer-events: none;
}

.swipe-experience-track .slider-option:hover .slider-label-text {
  color: var(--theme-scale-label-hover, rgba(255, 255, 255, 0.9));
}

.swipe-experience-track .slider-option input:checked ~ .slider-label-text {
  color: var(--text-primary, #fff);
  font-weight: 600;
}

/* Dim unselected labels when one is selected */
.swipe-experience-track:has(input:checked) .slider-option:not(:has(input:checked)) .slider-label-text {
  color: var(--theme-text-muted, rgba(255, 255, 255, 0.4));
}

/* Tooltip - DISABLED for swipe experience */
.swipe-experience-track .tooltip {
  display: none !important; /* Never show tooltips in swipe mode */
}

/* ============================================
   Desire Menu (Appears Above)
   ============================================ */

.swipe-desire-menu {
  position: absolute; /* Will be positioned above selected button */
  background: var(--theme-bg-primary); /* Solid background - uses theme color */
  border: 2px solid var(--theme-border-primary);
  border-radius: 16px; /* Rounded corners for modern look */
  padding: 0.75rem; /* Slightly more padding */
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.5);
  opacity: 0;
  transition: opacity 0.2s ease;
  min-width: 200px; /* Minimum width */
  max-width: 280px; /* Narrower max width */
  z-index: 1000;
  --arrow-offset: 0px; /* Set by JS for arrow alignment */
}

/* Arrow pointer at bottom of menu */
.swipe-desire-menu::after {
  content: '';
  position: absolute;
  bottom: -10px;
  left: calc(50% + var(--arrow-offset));
  transform: translateX(-50%);
  width: 0;
  height: 0;
  border-left: 10px solid transparent;
  border-right: 10px solid transparent;
  border-top: 10px solid var(--theme-border-primary);
}

/* Inner arrow (matches background) */
.swipe-desire-menu::before {
  content: '';
  position: absolute;
  bottom: -7px;
  left: calc(50% + var(--arrow-offset));
  transform: translateX(-50%);
  width: 0;
  height: 0;
  border-left: 8px solid transparent;
  border-right: 8px solid transparent;
  border-top: 8px solid var(--theme-bg-primary);
  z-index: 1;
}

/* Keep menu stable when visible */
.swipe-desire-menu.visible {
  opacity: 1;
}

/* Desire menu title (shows selected experience) */
.swipe-desire-title {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 0.5rem;
  padding-bottom: 0.5rem;
  border-bottom: 1px solid var(--theme-border);
}

.swipe-desire-exp-emoji {
  font-size: 1.25rem;
}

.swipe-desire-exp-label {
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--theme-text-primary);
}

/* Close button removed - tap outside to close */

/* Desire options container - compact spacing */
.swipe-desire-options {
  display: flex;
  flex-direction: column;
  gap: 0.2rem; /* Even tighter spacing */
  max-height: 320px;
  overflow-y: auto;
  overflow-x: hidden;
}

/* Individual desire button - compact with left vertical bar */
.swipe-desire-btn {
  position: relative;
  display: flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.35rem 0.5rem; /* More compact */
  background: var(--theme-bg);
  border: 2px solid transparent;
  border-radius: 6px;
  cursor: pointer;
  transition: all 0.15s ease;
  text-align: left;
  min-height: 36px;
  width: 100%; /* Full width of menu */
}

/* Vertical bar on left (only emoji height) - doubled width */
.swipe-desire-btn::before {
  content: '';
  position: absolute;
  left: 0.4rem;
  top: 50%;
  transform: translateY(-50%);
  width: 5px; /* Doubled from 2.5px */
  height: 1.3rem; /* Match smaller emoji */
  background: var(--option-color, var(--theme-border));
  border-radius: 3px;
}

.swipe-desire-btn:hover {
  background: var(--theme-bg-hover);
}

/* Selected state - thin outline */
.swipe-desire-btn.selected {
  border-color: var(--option-color, var(--theme-accent));
  background: var(--theme-bg-elevated);
}

/* Hover-selected state during swipe */
.swipe-desire-btn.hover-selected {
  border-color: var(--option-color, var(--theme-accent));
  background: var(--theme-bg-hover);
  transform: scale(1.02);
}

.swipe-desire-emoji {
  font-size: 1.3rem; /* Slightly smaller */
  min-width: 24px;
  text-align: center;
  margin-left: 0.6rem; /* Space for vertical bar */
}

/* SVG Icon specific styles for desire menu */
.swipe-desire-emoji.slider-icon-svg {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  color: var(--theme-scale-label-dim, rgba(180, 180, 180, 0.7));
}

.swipe-desire-emoji.slider-icon-svg svg {
  width: 1.2rem;
  height: 1.2rem;
}

.swipe-desire-btn:hover .swipe-desire-emoji.slider-icon-svg {
  color: var(--option-color, rgba(200, 200, 200, 0.9));
}

.swipe-desire-btn.selected .swipe-desire-emoji.slider-icon-svg,
.swipe-desire-btn.hover-selected .swipe-desire-emoji.slider-icon-svg {
  color: var(--option-color, #4f46e5);
  filter: drop-shadow(0 0 6px var(--option-color, #4f46e5));
}

/* === COLORED ICONS MODE for Desire Menu === */
body.colored-icons .swipe-desire-emoji.slider-icon-svg {
  color: var(--option-color, #4f46e5);
  opacity: 0.55;
  filter: saturate(0.8);
}

body.colored-icons .swipe-desire-btn:hover .swipe-desire-emoji.slider-icon-svg {
  color: var(--option-color, #4f46e5);
  opacity: 0.8;
  filter: saturate(0.9);
}

body.colored-icons .swipe-desire-btn.selected .swipe-desire-emoji.slider-icon-svg,
body.colored-icons .swipe-desire-btn.hover-selected .swipe-desire-emoji.slider-icon-svg {
  color: var(--option-color, #4f46e5);
  opacity: 1;
  filter: drop-shadow(0 0 6px var(--option-color, #4f46e5)) saturate(1);
}

.swipe-desire-label {
  font-size: 0.85rem; /* Smaller text */
  font-weight: 600;
  color: var(--theme-text-primary);
  flex: 1;
  white-space: nowrap; /* Prevent wrapping */
  overflow: hidden;
  text-overflow: ellipsis;
}

/* ============================================
   Mobile Adjustments
   ============================================ */

@media (max-width: 480px) {
  .swipe-desire-menu {
    padding: 0.5rem;
  }
  
  .swipe-desire-btn {
    padding: 0.3rem 0.5rem;
    min-height: 36px;
  }
  
  .swipe-desire-emoji {
    font-size: 1.25rem;
    margin-left: 0.5rem;
  }
  
  .swipe-desire-label {
    font-size: 0.85rem;
  }
}

/* ============================================
   Swipe Prompts (configurable labels)
   ============================================ */

.swipe-prompt {
  font-size: 0.9rem;
  font-weight: 500;
  color: var(--theme-text-secondary, rgba(255, 255, 255, 0.7));
  text-align: center;
  margin-bottom: 0.5rem;
}

.swipe-experience-prompt {
  margin-top: 0;
}

.swipe-desire-prompt {
  margin-bottom: 0.75rem;
  color: var(--theme-text-primary, #fff);
}

/* ============================================
   "Discuss?" Label Highlight Animation
   Fade-in effect after swipe selection (mobile only)
   ============================================ */

@keyframes swipe-label-highlight {
  0% {
    opacity: 0.3;
    transform: scale(0.95);
  }
  40% {
    opacity: 1;
    transform: scale(1.1);
    color: var(--theme-feedback-accent, #fbbf24);
  }
  100% {
    opacity: 1;
    transform: scale(1);
    color: inherit;
  }
}

.slider-label-right.swipe-highlight-in {
  animation: swipe-label-highlight 1.2s ease-out;
}
