/* BrandLab Module Styles */
.venn-container { max-width: 400px; margin: 0 auto; padding: var(--space-8) 0; }
.venn-container svg { width: 100%; height: auto; }
.venn-circle { fill-opacity: 0.15; stroke-width: 2; cursor: pointer; transition: all var(--transition-fast); }
.venn-circle:hover { fill-opacity: 0.25; }
.venn-label { font-family: var(--font-display); font-size: 12px; font-weight: 600; fill: var(--text-primary); text-anchor: middle; pointer-events: none; }
.venn-zone-label { font-size: 10px; fill: var(--text-secondary); text-anchor: middle; pointer-events: none; opacity: 0; transition: opacity var(--transition-base); }
.venn-container:hover .venn-zone-label { opacity: 1; }
.brand-sliders { display: flex; flex-direction: column; gap: var(--space-6); max-width: 500px; margin: 0 auto; }
.archetype-result { background: var(--bg-card); border: 2px solid var(--accent-violet); border-radius: var(--radius-xl); padding: var(--space-6); text-align: center; margin-top: var(--space-6); animation: scaleIn 0.4s var(--transition-spring); }
.archetype-result .archetype-name { font-family: var(--font-display); font-size: var(--text-2xl); font-weight: var(--weight-bold); color: var(--accent-violet); margin-bottom: var(--space-2); }
.archetype-result .archetype-desc { font-size: var(--text-sm); color: var(--text-secondary); margin-bottom: var(--space-4); }
.archetype-result .archetype-examples { display: flex; gap: var(--space-2); justify-content: center; flex-wrap: wrap; }
.archetype-result .archetype-examples .badge { background: rgba(123,94,255,0.12); color: var(--accent-violet); }
.word-cloud { position: relative; width: 100%; min-height: 250px; display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: var(--space-2); padding: var(--space-6); }
.word-cloud-item { font-family: var(--font-display); color: var(--text-primary); opacity: 0; animation: wordCloud 0.5s ease-out forwards; display: inline-block; padding: var(--space-1) var(--space-2); }
.brand-strategy-card { background: var(--bg-card); border: 1px solid var(--accent-gold); border-radius: var(--radius-xl); padding: var(--space-8); position: relative; overflow: hidden; }
.brand-strategy-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 4px; background: linear-gradient(90deg, var(--accent-gold), var(--accent-lime), var(--accent-violet)); }
.brand-strategy-card .brand-name-display { font-family: var(--font-display); font-size: var(--text-4xl); font-weight: var(--weight-bold); margin-bottom: var(--space-2); }
.brand-strategy-card .brand-tagline { font-style: italic; font-size: var(--text-lg); color: var(--text-secondary); margin-bottom: var(--space-6); }
.brand-strategy-card .brand-values { display: flex; gap: var(--space-2); flex-wrap: wrap; margin-bottom: var(--space-6); }
.brand-strategy-card .brand-value-pill { padding: var(--space-1) var(--space-3); background: rgba(189,255,71,0.1); border: 1px solid rgba(189,255,71,0.2); border-radius: var(--radius-full); font-size: var(--text-sm); color: var(--accent-lime); }
.brand-strategy-card .brand-enemy { padding: var(--space-4); background: rgba(255,92,92,0.08); border: 1px solid rgba(255,92,92,0.15); border-radius: var(--radius-md); margin-top: var(--space-4); }
.brand-strategy-card .brand-enemy .enemy-label { font-size: var(--text-xs); color: var(--accent-coral); font-weight: var(--weight-bold); text-transform: uppercase; letter-spacing: 0.05em; margin-bottom: var(--space-1); }
.brand-strategy-card .brand-enemy p { font-size: var(--text-sm); color: var(--text-secondary); }
.brand-download-btn { margin-top: var(--space-6); }
@media print {
  .brand-strategy-card { border: 2px solid #333; box-shadow: none; }
  .brand-strategy-card::before { display: none; }
  body * { visibility: hidden; }
  .brand-strategy-card, .brand-strategy-card * { visibility: visible; }
  .brand-strategy-card { position: absolute; left: 0; top: 0; width: 100%; }
  .brand-download-btn { display: none; }
}
