/**
 * CHUNK 160A: Builder Thinking Narrative Styles
 * 
 * Premium "AI bartender thinking" animation styles
 * Replaces generic spinners with brand-aligned craft experience
 */

.bb-thinking-narrative {
  display: flex !important;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: var(--space-xl, 48px) var(--space-md, 24px);
  text-align: center;
  min-height: 200px;
  opacity: 1;
  transition: opacity 0.3s ease;
  visibility: visible !important;
  width: 100%;
  position: relative;
  z-index: 1;
}

/* Ensure thinking narrative is visible inside result containers */
#roundThinkingContainer,
#scratchThinkingContainer,
#makeThinkingContainer,
#mocktailThinkingContainer {
  display: block !important;
  visibility: visible !important;
  width: 100%;
  min-height: 200px;
}

#roundThinkingContainer[style*="display: none"],
#scratchThinkingContainer[style*="display: none"],
#makeThinkingContainer[style*="display: none"],
#mocktailThinkingContainer[style*="display: none"] {
  display: none !important;
}

/* Override grid layout when thinking narrative container is visible */
#roundThinkingContainer[style*="display: block"],
#roundThinkingContainer[style*="display:block"] {
  display: block !important;
  visibility: visible !important;
  width: 100% !important;
  min-height: 200px !important;
}

#scratchThinkingContainer[style*="display: block"],
#scratchThinkingContainer[style*="display:block"] {
  display: block !important;
  visibility: visible !important;
  width: 100% !important;
  min-height: 200px !important;
}

/* Override grid layout when thinking narrative is shown */
.round-builder-drinks-container:has(#roundThinkingContainer[style*="display: block"]),
.round-builder-drinks-container:has(#roundThinkingContainer[style*="display:block"]),
.start-from-scratch-drinks-container:has(#scratchThinkingContainer[style*="display: block"]),
.start-from-scratch-drinks-container:has(#scratchThinkingContainer[style*="display:block"]) {
  display: block !important;
  grid-template-columns: none !important;
}

/* Fallback: if :has() not supported, use class-based approach */
.round-builder-drinks-container.showing-thinking-narrative,
.start-from-scratch-drinks-container.showing-thinking-narrative,
.mocktail-builder-drinks-container.showing-thinking-narrative {
  display: block !important;
  grid-template-columns: none !important;
}

#mocktailThinkingContainer[style*="display: block"],
#mocktailThinkingContainer[style*="display:block"] {
  display: block !important;
  visibility: visible !important;
  width: 100% !important;
  min-height: 200px !important;
}

.bb-thinking-narrative__headline {
  font-size: var(--ds-text-xl, 1.25rem);
  font-weight: 500;
  color: var(--bb-deep, #0F1118);
  margin: 0 0 var(--space-sm, 12px) 0;
  line-height: 1.4;
  transition: opacity 0.2s ease;
}

.bb-thinking-narrative__explanation {
  font-size: var(--ds-text-base, 1rem);
  color: var(--bb-slate, #64748B);
  margin: 0 0 var(--space-md, 24px) 0;
  line-height: 1.5;
  max-width: 500px;
}

.bb-thinking-narrative__micro-copy {
  font-size: var(--ds-text-sm, 0.875rem);
  color: var(--bb-slate, #64748B);
  margin: 0 0 var(--space-md, 24px) 0;
  font-weight: 500;
  letter-spacing: 0.05em;
}

.bb-thinking-narrative__first-run {
  font-size: var(--ds-text-sm, 0.875rem);
  color: var(--bb-slate, #64748B);
  margin: var(--space-md, 24px) 0 0 0;
  padding: var(--space-sm, 12px) var(--space-md, 24px);
  background: var(--bb-slate-light, #F1F5F9);
  border-radius: var(--ds-radius-md, 12px);
  max-width: 500px;
  line-height: 1.5;
}

/* Animation: Shimmering dots (replaces spinner) */
.bb-thinking-narrative__animation {
  margin-top: var(--space-md, 24px);
}

.bb-thinking-dots {
  display: flex;
  gap: var(--space-xs, 8px);
  align-items: center;
  justify-content: center;
}

.bb-thinking-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--bb-primary, #F97316);
  opacity: 0.4;
  animation: bb-thinking-pulse 1.4s ease-in-out infinite;
}

.bb-thinking-dot:nth-child(1) {
  animation-delay: 0s;
}

.bb-thinking-dot:nth-child(2) {
  animation-delay: 0.2s;
}

.bb-thinking-dot:nth-child(3) {
  animation-delay: 0.4s;
}

@keyframes bb-thinking-pulse {
  0%, 100% {
    opacity: 0.4;
    transform: scale(1);
  }
  50% {
    opacity: 1;
    transform: scale(1.2);
  }
}

/* Mobile adjustments */
@media (max-width: 768px) {
  .bb-thinking-narrative {
    padding: var(--space-lg, 32px) var(--space-sm, 16px);
    min-height: 150px;
  }
  
  .bb-thinking-narrative__headline {
    font-size: var(--ds-text-lg, 1.125rem);
  }
  
  .bb-thinking-narrative__explanation {
    font-size: var(--ds-text-sm, 0.875rem);
  }
  
  .bb-thinking-narrative__first-run {
    font-size: var(--ds-text-xs, 0.75rem);
    padding: var(--space-xs, 8px) var(--space-sm, 16px);
  }
}

/* Dark mode support */
[data-bar-mode="dark"] .bb-thinking-narrative__headline,
.theme-halytic .bb-thinking-narrative__headline {
  color: var(--bb-white, #FFFFFF);
}

[data-bar-mode="dark"] .bb-thinking-narrative__explanation,
.theme-halytic .bb-thinking-narrative__explanation,
[data-bar-mode="dark"] .bb-thinking-narrative__micro-copy,
.theme-halytic .bb-thinking-narrative__micro-copy {
  color: var(--bb-slate-light, #CBD5E1);
}

[data-bar-mode="dark"] .bb-thinking-narrative__first-run,
.theme-halytic .bb-thinking-narrative__first-run {
  background: rgba(255, 255, 255, 0.05);
  color: var(--bb-slate-light, #CBD5E1);
}
