/* Created by: Claude Date: 2026-01-03 Purpose: Styles pour VideoGrid Refs: CLAUDE.md */ .gridContainer { position: relative; width: 100%; height: 100%; } .videoGrid { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: var(--spacing-md); padding: var(--spacing-lg); width: 100%; height: 100%; overflow-y: auto; } .localPreview { position: absolute; bottom: 20px; right: 20px; width: 240px; height: 135px; border-radius: 8px; overflow: hidden; border: 2px solid var(--accent-primary); box-shadow: 0 4px 12px rgba(0, 0, 0, 0.4); z-index: 10; transition: all 0.3s ease; } .localPreview:hover { transform: scale(1.05); box-shadow: 0 6px 16px rgba(0, 0, 0, 0.5); } .localVideo { width: 100%; height: 100%; object-fit: cover; transform: scaleX(-1); /* Effet miroir pour la caméra locale */ } .localLabel { position: absolute; bottom: 8px; left: 8px; right: 8px; color: white; font-size: 12px; font-weight: 600; background: rgba(0, 0, 0, 0.6); padding: 4px 8px; border-radius: 4px; text-align: center; } .videoContainer { position: relative; background: var(--bg-secondary); border-radius: 8px; overflow: hidden; aspect-ratio: 16 / 9; border: 1px solid var(--border-primary); transition: all 0.3s ease; } .videoContainer.speaking { border: 2px solid var(--accent-success); box-shadow: 0 0 20px rgba(166, 226, 46, 0.3); transform: scale(1.02); } .video { width: 100%; height: 100%; object-fit: cover; } .videoOverlay { position: absolute; bottom: 0; left: 0; right: 0; background: linear-gradient(to top, rgba(0, 0, 0, 0.7), transparent); padding: 0.5rem 1rem; display: flex; justify-content: space-between; align-items: center; gap: var(--spacing-sm); } .videoLabel { color: var(--text-primary); font-size: 14px; font-weight: 600; flex: 1; display: flex; align-items: center; gap: 6px; } .speakingIcon { animation: pulse 1s ease-in-out infinite; } @keyframes pulse { 0%, 100% { opacity: 1; transform: scale(1); } 50% { opacity: 0.7; transform: scale(1.2); } } .noVideo { display: flex; flex-direction: column; align-items: center; justify-content: center; width: 100%; height: 100%; background: var(--bg-primary); } .noVideoIcon { font-size: 4rem; margin-bottom: 1rem; opacity: 0.5; } .emptyState { display: flex; align-items: center; justify-content: center; width: 100%; height: 100%; padding: var(--spacing-lg); } .emptyMessage { color: var(--text-secondary); font-size: 16px; text-align: center; }