/* ═══════════════════════════════════════════════════════════════
   OTIS IA — Frontend (theme-isolated)
   Terrain d'Idées brand palette
   ═══════════════════════════════════════════════════════════════ */

/* ── Hard reset ───────────────────────────────────────────── */
.sia-root {
  all: initial;
  display: flex;
  flex-direction: column;
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  color: var(--sia-txt);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  line-height: 1.5;
  font-size: 15px;
  box-sizing: border-box;
  height: 85vh;
  min-height: 500px;
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 4px 40px rgba(61, 54, 41, 0.12);
}

.sia-root *,
.sia-root *::before,
.sia-root *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
  border: 0;
  font: inherit;
  color: inherit;
  background: none;
  text-decoration: none;
  list-style: none;
}

/* ── Palette (Terrain d'Idées) ────────────────────────────── */
.sia-root {
  --sia-bg:          #F5F0E8;
  --sia-bg-light:    #FDFAF5;
  --sia-bg-panel:    #FFFFFF;
  --sia-txt:         #3D3629;
  --sia-txt-soft:    #8A7A66;
  --sia-txt-mid:     #6B5B4A;
  --sia-border:      #E2D9CC;
  --sia-border-light:#EDE7DD;
  --sia-accent:      #6B5B4A;
  --sia-accent-soft: #A08B74;
  --sia-accent-h:    #7D6B58;
  --sia-accent-glow: rgba(107, 91, 74, 0.15);
  --sia-danger:      #C4564A;
  --sia-danger-h:    #D4665A;
  --sia-success:     #5A8A5E;
  --sia-highlight:   rgba(107, 91, 74, 0.1);
  --sia-highlight-border: #6B5B4A;
}

/* ── Fullscreen ───────────────────────────────────────────── */
.sia-fullscreen {
  position: fixed !important;
  inset: 0 !important;
  z-index: 999999 !important;
  height: 100vh !important;
  border-radius: 0 !important;
}

/* ══════════════════════════════════════════════════════════════
   HEADER
   ══════════════════════════════════════════════════════════════ */
.sia-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 24px;
  background: var(--sia-bg);
  border-bottom: 1px solid var(--sia-border);
  flex-shrink: 0;
}

.sia-header-left {
  display: flex;
  align-items: center;
  gap: 16px;
}

.sia-logo {
  display: flex;
  align-items: center;
  gap: 8px;
  font-weight: 300;
  font-size: 1.15rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--sia-txt-soft);
  user-select: none;
}
.sia-logo-icon {
  flex-shrink: 0;
  filter: drop-shadow(0 1px 2px rgba(0,0,0,0.15));
}
.sia-logo span {
  font-weight: 600;
  color: var(--sia-accent);
}

.sia-status {
  font-size: 0.82rem;
  color: var(--sia-txt-soft);
  padding: 3px 10px;
  border-radius: 12px;
  background: var(--sia-bg-light);
}

.sia-header-right {
  display: flex;
  align-items: center;
  gap: 20px;
}

.sia-timer {
  font-family: 'SF Mono', 'Fira Code', 'Consolas', monospace;
  font-size: 1.1rem;
  font-weight: 500;
  color: var(--sia-accent);
  letter-spacing: 0.05em;
  min-width: 55px;
  text-align: center;
}

/* ── Mic controls ─────────────────────────────────────────── */
.sia-mic-controls {
  display: flex;
  align-items: center;
  gap: 10px;
}

.sia-sensitivity-label {
  display: flex;
  align-items: center;
  gap: 6px;
  cursor: pointer;
  color: var(--sia-txt-soft);
}

.sia-sensitivity {
  -webkit-appearance: none;
  appearance: none;
  width: 80px;
  height: 4px;
  border-radius: 2px;
  background: var(--sia-border);
  outline: none;
  cursor: pointer;
}
.sia-sensitivity::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: var(--sia-accent);
  cursor: pointer;
  transition: transform 0.15s;
}
.sia-sensitivity::-webkit-slider-thumb:hover {
  transform: scale(1.2);
}

.sia-level-meter {
  width: 60px;
  height: 6px;
  background: var(--sia-border-light);
  border-radius: 3px;
  overflow: hidden;
}
.sia-level-bar {
  height: 100%;
  width: 0%;
  background: var(--sia-accent-soft);
  border-radius: 3px;
  transition: width 0.08s ease-out, background-color 0.15s;
}

/* ══════════════════════════════════════════════════════════════
   MAIN: SPLIT PANEL
   ══════════════════════════════════════════════════════════════ */
.sia-main {
  display: flex;
  flex: 1;
  overflow: hidden;
}

.sia-panel {
  display: flex;
  flex-direction: column;
  flex: 1;
  overflow: hidden;
}

.sia-panel-left {
  background: var(--sia-bg-light);
  border-right: 1px solid var(--sia-border);
}

.sia-panel-right {
  background: var(--sia-bg-panel);
}

.sia-panel-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 20px;
  border-bottom: 1px solid var(--sia-border-light);
  flex-shrink: 0;
}

.sia-panel-header h3 {
  font-size: 0.78rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--sia-txt-soft);
}

.sia-segment-count {
  font-size: 0.72rem;
  color: var(--sia-txt-soft);
  background: var(--sia-bg);
  padding: 2px 8px;
  border-radius: 8px;
}

.sia-btn-show-all {
  font-size: 0.72rem;
  color: var(--sia-accent);
  cursor: pointer;
  padding: 2px 8px;
  border-radius: 8px;
  background: var(--sia-accent-glow);
  transition: background 0.2s;
}
.sia-btn-show-all:hover {
  background: var(--sia-highlight);
}

/* ── Transcript area ──────────────────────────────────────── */
.sia-transcript {
  flex: 1;
  overflow-y: auto;
  padding: 16px 20px;
  scroll-behavior: smooth;
}

.sia-transcript::-webkit-scrollbar       { width: 4px; }
.sia-transcript::-webkit-scrollbar-track  { background: transparent; }
.sia-transcript::-webkit-scrollbar-thumb { background: var(--sia-border); border-radius: 2px; }

.sia-placeholder {
  text-align: center;
  color: var(--sia-txt-soft);
  font-size: 0.88rem;
  padding: 40px 20px;
  font-style: italic;
}

/* ── Segments ─────────────────────────────────────────────── */
.sia-seg {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 10px 14px;
  margin-bottom: 6px;
  border-radius: 10px;
  border-left: 3px solid transparent;
  cursor: pointer;
  transition: all 0.3s ease;
  opacity: 0;
  transform: translateY(8px);
}
.sia-seg-visible {
  opacity: 1;
  transform: translateY(0);
}

.sia-seg:hover {
  background: var(--sia-highlight);
}

.sia-seg-has-complement {
  border-left-color: var(--sia-accent-soft);
}

.sia-seg.sia-highlight {
  background: var(--sia-highlight);
  border-left-color: var(--sia-highlight-border);
  box-shadow: 0 0 0 1px var(--sia-accent-glow);
}

.sia-seg-time {
  font-family: 'SF Mono', 'Fira Code', monospace;
  font-size: 0.7rem;
  color: var(--sia-txt-soft);
  white-space: nowrap;
  padding-top: 2px;
  min-width: 38px;
}

.sia-seg-text {
  flex: 1;
  font-size: 0.9rem;
  line-height: 1.55;
  color: var(--sia-txt);
}

.sia-seg-indicator {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
  margin-top: 5px;
  transition: background 0.3s;
}
.sia-seg-has-complement .sia-seg-indicator {
  background: var(--sia-accent-soft);
}

/* ── Interim text ─────────────────────────────────────────── */
.sia-interim {
  padding: 8px 14px;
  font-size: 0.88rem;
  color: var(--sia-txt-soft);
  font-style: italic;
  min-height: 20px;
}

/* ══════════════════════════════════════════════════════════════
   COMPLEMENTS
   ══════════════════════════════════════════════════════════════ */
.sia-complements {
  flex: 1;
  overflow-y: auto;
  padding: 16px 20px;
  scroll-behavior: smooth;
}

.sia-complements::-webkit-scrollbar       { width: 4px; }
.sia-complements::-webkit-scrollbar-track  { background: transparent; }
.sia-complements::-webkit-scrollbar-thumb { background: var(--sia-border); border-radius: 2px; }

.sia-complement {
  background: var(--sia-bg-light);
  border: 1px solid var(--sia-border-light);
  border-radius: 12px;
  padding: 14px 16px;
  margin-bottom: 12px;
  cursor: pointer;
  transition: all 0.4s cubic-bezier(0.22, 1, 0.36, 1);
  opacity: 0;
  transform: translateX(20px);
}
.sia-complement-visible {
  opacity: 1;
  transform: translateX(0);
}

.sia-complement:hover {
  border-color: var(--sia-accent-soft);
  box-shadow: 0 2px 12px var(--sia-accent-glow);
}

.sia-complement.sia-highlight {
  border-color: var(--sia-highlight-border);
  background: var(--sia-highlight);
  box-shadow: 0 2px 16px var(--sia-accent-glow);
}

.sia-complement-header {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 8px;
}

.sia-complement-ref {
  font-size: 0.68rem;
  font-weight: 600;
  color: var(--sia-bg-light);
  background: var(--sia-accent-soft);
  padding: 2px 8px;
  border-radius: 6px;
  white-space: nowrap;
  flex-shrink: 0;
}

.sia-complement-title {
  font-size: 0.88rem;
  font-weight: 600;
  color: var(--sia-txt);
  flex: 1;
  line-height: 1.3;
}

.sia-complement-confidence {
  font-size: 0.68rem;
  font-weight: 600;
  padding: 2px 6px;
  border-radius: 6px;
  white-space: nowrap;
}
.sia-conf-high { background: rgba(90, 138, 94, 0.15); color: var(--sia-success); }
.sia-conf-mid  { background: rgba(107, 91, 74, 0.12); color: var(--sia-accent); }
.sia-conf-low  { background: rgba(196, 86, 74, 0.12); color: var(--sia-danger); }

.sia-complement-badge {
  font-size: 0.68rem;
  font-weight: 600;
  padding: 2px 8px;
  border-radius: 6px;
  background: rgba(90, 138, 94, 0.15);
  color: var(--sia-success);
  white-space: nowrap;
}

.sia-complement-body {
  font-size: 0.84rem;
  line-height: 1.65;
  color: var(--sia-txt-mid);
}
.sia-complement-body strong { font-weight: 600; color: var(--sia-txt); }
.sia-complement-body em { font-style: italic; }
.sia-complement-body code {
  font-family: 'SF Mono', 'Fira Code', monospace;
  font-size: 0.8em;
  background: var(--sia-bg);
  padding: 1px 5px;
  border-radius: 4px;
}
.sia-complement-body br { display: block; margin-top: 4px; content: ''; }

.sia-complement-keywords {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  margin-top: 10px;
}

.sia-keyword {
  font-size: 0.7rem;
  color: var(--sia-accent);
  background: var(--sia-accent-glow);
  padding: 2px 8px;
  border-radius: 8px;
}

/* ── Complement media ─────────────────────────────────────── */
/* ── Media: images & videos ─────────────────────────────── */
.sia-media-wrap {
  margin-top: 8px;
}

.sia-complement-img {
  display: block;
  width: 100%;
  max-width: 400px;
  border-radius: 8px;
}

.sia-clickable-img {
  cursor: zoom-in;
  transition: transform 0.15s, box-shadow 0.15s;
}
.sia-clickable-img:hover {
  transform: scale(1.02);
  box-shadow: 0 4px 16px rgba(61, 54, 41, 0.18);
}

.sia-complement-video {
  display: block;
  width: 100%;
  max-width: 480px;
  border-radius: 8px;
  background: #000;
}

.sia-media-actions {
  margin-top: 6px;
  display: flex;
  gap: 8px;
}

.sia-btn-download {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 4px 10px;
  font-size: 12px;
  font-family: inherit;
  color: var(--sia-accent);
  background: var(--sia-surface);
  border: 1px solid var(--sia-border);
  border-radius: 6px;
  text-decoration: none;
  cursor: pointer;
  transition: background 0.15s, color 0.15s;
}
.sia-btn-download:hover {
  background: var(--sia-accent);
  color: #fff;
}

/* ── Lightbox ──────────────────────────────────────────── */
.sia-lightbox {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 999999;
  align-items: center;
  justify-content: center;
}
.sia-lightbox.sia-lightbox-open {
  display: flex;
}

.sia-lightbox-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.80);
  animation: sia-fade-in 0.2s ease;
}

.sia-lightbox-content {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  max-width: 90vw;
  max-height: 90vh;
  animation: sia-zoom-in 0.2s ease;
}

.sia-lightbox-content img {
  max-width: 90vw;
  max-height: 80vh;
  border-radius: 8px;
  box-shadow: 0 8px 40px rgba(0, 0, 0, 0.5);
  object-fit: contain;
}

.sia-lightbox-actions {
  display: flex;
  gap: 10px;
  align-items: center;
}

.sia-lightbox-close {
  padding: 6px 16px;
  font-size: 13px;
  font-family: inherit;
  color: #fff;
  background: rgba(255, 255, 255, 0.15);
  border: 1px solid rgba(255, 255, 255, 0.3);
  border-radius: 6px;
  cursor: pointer;
  transition: background 0.15s;
}
.sia-lightbox-close:hover {
  background: rgba(255, 255, 255, 0.3);
}

.sia-lightbox .sia-lightbox-dl {
  color: #fff;
  border-color: rgba(255, 255, 255, 0.3);
  background: rgba(255, 255, 255, 0.15);
}
.sia-lightbox .sia-lightbox-dl:hover {
  background: rgba(255, 255, 255, 0.3);
  color: #fff;
}

@keyframes sia-fade-in {
  from { opacity: 0; }
  to   { opacity: 1; }
}
@keyframes sia-zoom-in {
  from { transform: scale(0.9); opacity: 0; }
  to   { transform: scale(1); opacity: 1; }
}

/* ── Extra complement (model calls) ───────────────────────── */
.sia-complement-extra {
  border-left: 3px solid var(--sia-accent-soft);
}

/* ── Badge variants ───────────────────────────────────────── */
.sia-badge-text {
  background: rgba(107, 91, 74, 0.12) !important;
  color: var(--sia-accent) !important;
}
.sia-badge-image {
  background: rgba(90, 138, 94, 0.15) !important;
  color: var(--sia-success) !important;
}
.sia-badge-video {
  background: rgba(90, 100, 180, 0.12) !important;
  color: #5A64B4 !important;
}

/* ── Skipped segment ──────────────────────────────────────── */
.sia-seg-skipped {
  opacity: 0.5;
}
.sia-seg-skipped .sia-seg-indicator {
  background: var(--sia-border);
}

/* ── Error complement ─────────────────────────────────────── */
.sia-complement-error {
  border-color: rgba(196, 86, 74, 0.3);
  background: rgba(196, 86, 74, 0.04);
}
.sia-complement-error-msg {
  color: var(--sia-danger) !important;
  font-size: 0.82rem !important;
}

/* ── Loading animation ────────────────────────────────────── */
.sia-complement-loading {
  opacity: 0.7;
}

.sia-complement-model-pending {
  border-left: 3px solid var(--sia-accent);
  background: linear-gradient(90deg, rgba(107, 91, 74, 0.06) 0%, transparent 100%);
}

.sia-model-pending-label {
  font-style: italic;
  color: var(--sia-accent);
  font-size: 13px;
}

.sia-model-timer {
  font-variant-numeric: tabular-nums;
  opacity: 0.7;
}

.sia-complement-loader {
  display: flex;
  gap: 4px;
  align-items: center;
}

.sia-dot {
  display: inline-block;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--sia-accent-soft);
  animation: sia-bounce 1.2s infinite ease-in-out;
}
.sia-dot:nth-child(2) { animation-delay: 0.15s; }
.sia-dot:nth-child(3) { animation-delay: 0.3s; }

@keyframes sia-bounce {
  0%, 80%, 100% { transform: scale(0.6); opacity: 0.4; }
  40% { transform: scale(1); opacity: 1; }
}

/* ══════════════════════════════════════════════════════════════
   CONTROLS
   ══════════════════════════════════════════════════════════════ */
.sia-controls {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 14px;
  padding: 16px;
  background: var(--sia-bg);
  border-top: 1px solid var(--sia-border);
  flex-shrink: 0;
}

/* ── Mute button ──────────────────────────────────────────── */
.sia-btn-mute {
  display: none; /* hidden until session is active */
  align-items: center;
  justify-content: center;
  width: 42px;
  height: 42px;
  border-radius: 50%;
  background: var(--sia-border);
  color: var(--sia-txt-mid);
  cursor: pointer;
  transition: background 0.25s, transform 0.2s, opacity 0.3s;
  -webkit-appearance: none;
  appearance: none;
  outline: none;
  opacity: 0.85;
}
.sia-btn-mute:hover {
  background: var(--sia-accent-h);
  color: var(--sia-bg-light);
  transform: scale(1.08);
  opacity: 1;
}
.sia-btn-mute:active { transform: scale(0.95); }

/* Show when session active */
.sia-session-active .sia-btn-mute { display: flex; }

/* Muted icon toggle */
.sia-btn-mute .sia-ico-muted  { display: none; }
.sia-btn-mute .sia-ico-unmuted { display: block; }

.sia-btn-mute.sia-muted {
  background: var(--sia-danger);
  color: var(--sia-bg-light);
  opacity: 1;
}
.sia-btn-mute.sia-muted:hover { background: var(--sia-danger-h); }
.sia-btn-mute.sia-muted .sia-ico-unmuted { display: none; }
.sia-btn-mute.sia-muted .sia-ico-muted  { display: block; }

/* Muted state: dim panels slightly */
.sia-mic-muted .sia-transcript { opacity: 0.6; }
.sia-mic-muted .sia-interim { display: none; }
.sia-mic-muted .sia-level-bar { width: 0% !important; }

.sia-btn-mic {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: var(--sia-accent);
  color: var(--sia-bg-light);
  cursor: pointer;
  transition: background 0.3s, transform 0.2s, box-shadow 0.3s;
  box-shadow: 0 4px 20px rgba(107, 91, 74, 0.25);
  -webkit-appearance: none;
  appearance: none;
  outline: none;
}
.sia-btn-mic:hover {
  background: var(--sia-accent-h);
  transform: scale(1.06);
  box-shadow: 0 6px 28px rgba(107, 91, 74, 0.35);
}
.sia-btn-mic:active { transform: scale(0.97); }

.sia-btn-mic .sia-ico-stop { display: none; }

.sia-btn-mic.sia-active {
  background: var(--sia-danger);
  box-shadow: 0 4px 20px rgba(196, 86, 74, 0.35);
  animation: sia-pulse 2s infinite;
}
.sia-btn-mic.sia-active:hover { background: var(--sia-danger-h); }
.sia-btn-mic.sia-active .sia-ico-mic  { display: none; }
.sia-btn-mic.sia-active .sia-ico-stop { display: block; }

@keyframes sia-pulse {
  0%, 100% { box-shadow: 0 4px 20px rgba(196, 86, 74, 0.35); }
  50%      { box-shadow: 0 4px 30px rgba(196, 86, 74, 0.55); }
}

/* ══════════════════════════════════════════════════════════════
   RESPONSIVE
   ══════════════════════════════════════════════════════════════ */
@media (max-width: 768px) {
  .sia-main {
    flex-direction: column;
  }
  .sia-panel-left {
    border-right: none;
    border-bottom: 1px solid var(--sia-border);
    max-height: 40vh;
  }
  .sia-panel-right {
    flex: 1;
  }
  .sia-header {
    flex-wrap: wrap;
    gap: 10px;
    padding: 12px 16px;
  }
  .sia-mic-controls { display: none; }
  .sia-transcript, .sia-complements { padding: 12px 14px; }
}

@media (max-width: 480px) {
  .sia-root { font-size: 14px; min-height: 400px; }
  .sia-logo { font-size: 1rem; }
  .sia-panel-header { padding: 8px 14px; }
  .sia-seg { padding: 8px 10px; }
  .sia-complement { padding: 10px 12px; }
}

/* ══════════════════════════════════════════════════════════════
   LOGIN GATE (utilisateurs non connectés / non autorisés)
   ══════════════════════════════════════════════════════════════ */
.sia-login-gate {
  all: initial;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 50vh;
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  -webkit-font-smoothing: antialiased;
}
.sia-login-box {
  background: #FDFAF5;
  border: 1px solid #E2D9CC;
  border-radius: 16px;
  padding: 40px 48px;
  text-align: center;
  max-width: 420px;
  width: 100%;
  box-shadow: 0 4px 40px rgba(61, 54, 41, 0.08);
}
.sia-login-box h2 {
  font-size: 1.4rem;
  font-weight: 300;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: #8A7A66;
  margin-bottom: 12px;
}
.sia-login-box h2 span {
  font-weight: 600;
  color: #6B5B4A;
}
.sia-login-box p {
  font-size: 0.88rem;
  color: #8A7A66;
  margin-bottom: 20px;
}
.sia-login-box form {
  text-align: left;
}
.sia-login-box label {
  display: block;
  font-size: 0.82rem;
  font-weight: 500;
  color: #6B5B4A;
  margin-bottom: 4px;
}
.sia-login-box input[type="text"],
.sia-login-box input[type="password"] {
  width: 100%;
  padding: 8px 12px;
  border: 1px solid #E2D9CC;
  border-radius: 8px;
  font-size: 0.88rem;
  margin-bottom: 12px;
  background: #fff;
  color: #3D3629;
}
.sia-login-box input[type="text"]:focus,
.sia-login-box input[type="password"]:focus {
  outline: none;
  border-color: #6B5B4A;
}
.sia-login-box input[type="submit"] {
  background: #6B5B4A;
  color: #fff;
  border: none;
  padding: 10px 28px;
  border-radius: 8px;
  font-size: 0.88rem;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.2s;
  margin-top: 4px;
}
.sia-login-box input[type="submit"]:hover {
  background: #7D6B58;
}

/* ══════════════════════════════════════════════════════════════
   HISTORY BUTTON ("Mes sessions")
   ══════════════════════════════════════════════════════════════ */
.sia-btn-history {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 0.75rem;
  font-weight: 500;
  color: var(--sia-txt-soft);
  background: var(--sia-bg-light);
  border: 1px solid var(--sia-border);
  padding: 5px 12px;
  border-radius: 8px;
  cursor: pointer;
  transition: all 0.2s;
  -webkit-appearance: none;
  appearance: none;
  outline: none;
  white-space: nowrap;
}
.sia-btn-history:hover {
  background: var(--sia-bg-panel);
  border-color: var(--sia-accent-soft);
  color: var(--sia-accent);
}
.sia-btn-history svg { flex-shrink: 0; }
/* Hide during active session */
.sia-session-active .sia-btn-history { display: none; }

/* ══════════════════════════════════════════════════════════════
   FRONT-END MODALS (liste + détail)
   ══════════════════════════════════════════════════════════════ */
.sia-modal-overlay-front {
  position: absolute;
  inset: 0;
  background: rgba(61, 54, 41, 0.4);
  backdrop-filter: blur(3px);
  z-index: 10;
}

.sia-modal-front {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 11;
  background: var(--sia-bg-panel);
  border-radius: 14px;
  box-shadow: 0 10px 60px rgba(61, 54, 41, 0.2);
  width: 90%;
  max-width: 560px;
  max-height: 80%;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

.sia-modal-front-large { max-width: 1100px; }

.sia-modal-front-header {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 20px;
  border-bottom: 1px solid var(--sia-border-light);
  flex-shrink: 0;
}
.sia-modal-front-header h2 {
  font-size: 0.92rem;
  font-weight: 600;
  color: var(--sia-txt);
  flex: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.sia-modal-front-close {
  font-size: 1.4rem;
  color: var(--sia-txt-soft);
  cursor: pointer;
  line-height: 1;
  transition: color 0.2s;
  flex-shrink: 0;
  background: none;
  border: none;
  -webkit-appearance: none;
  appearance: none;
}
.sia-modal-front-close:hover { color: var(--sia-danger); }

.sia-modal-front-back {
  font-size: 0.78rem;
  color: var(--sia-accent);
  cursor: pointer;
  background: none;
  border: none;
  -webkit-appearance: none;
  appearance: none;
  padding: 4px 8px;
  border-radius: 6px;
  transition: background 0.15s;
  flex-shrink: 0;
}
.sia-modal-front-back:hover { background: var(--sia-highlight); }

.sia-modal-front-body {
  padding: 16px 20px;
  overflow-y: auto;
  flex: 1;
}

/* ── Download buttons in detail modal header ───────────── */
.sia-detail-downloads {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-shrink: 0;
}
.sia-dl-btn {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 0.68rem;
  font-weight: 500;
  color: var(--sia-accent);
  background: var(--sia-bg-light);
  border: 1px solid var(--sia-border);
  padding: 3px 10px;
  border-radius: 6px;
  cursor: pointer;
  transition: all 0.15s;
  -webkit-appearance: none;
  appearance: none;
  white-space: nowrap;
}
.sia-dl-btn:hover {
  background: var(--sia-bg);
  border-color: var(--sia-accent-soft);
}
.sia-dl-btn svg { flex-shrink: 0; }

/* ── Sessions list table ────────────────────────────────── */
.sia-hist-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.82rem;
}
.sia-hist-table thead th {
  text-align: left;
  font-size: 0.68rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--sia-txt-soft);
  padding: 8px 10px;
  border-bottom: 2px solid var(--sia-border-light);
}
.sia-hist-table td {
  padding: 8px 10px;
  border-bottom: 1px solid var(--sia-border-light);
  vertical-align: middle;
}
.sia-hist-title { font-weight: 500; color: var(--sia-txt); }

.sia-hist-badge {
  display: inline-block;
  padding: 1px 8px;
  border-radius: 8px;
  font-size: 0.68rem;
  font-weight: 600;
}
.sia-hist-done   { background: rgba(90,138,94,0.12); color: var(--sia-success); }
.sia-hist-active { background: rgba(107,91,74,0.12); color: var(--sia-accent); }
.sia-hist-warn   { background: rgba(196,86,74,0.10); color: var(--sia-danger); }

.sia-hist-view-btn {
  font-size: 0.75rem;
  color: var(--sia-accent);
  background: var(--sia-bg-light);
  border: 1px solid var(--sia-border);
  padding: 4px 12px;
  border-radius: 6px;
  cursor: pointer;
  transition: all 0.15s;
  -webkit-appearance: none;
  appearance: none;
}
.sia-hist-view-btn:hover {
  background: var(--sia-bg);
  border-color: var(--sia-accent-soft);
}

.sia-hist-info {
  text-align: center;
  font-size: 0.72rem;
  color: var(--sia-txt-soft);
  padding: 10px;
  font-style: italic;
}

/* ── Detail viewer (2 colonnes : transcription + compléments) ── */
.sia-detail-viewer {
  display: flex;
  gap: 14px;
  min-height: 350px;
}
.sia-detail-left {
  flex: 1;
  overflow-y: auto;
  padding-right: 14px;
  border-right: 1px solid var(--sia-border-light);
}
.sia-detail-right {
  flex: 1;
  overflow-y: auto;
}
.sia-detail-left,
.sia-detail-right { max-height: 55vh; }
.sia-detail-viewer h3 {
  font-size: 0.72rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--sia-txt-soft);
  margin-bottom: 10px;
}

.sia-v-seg-f {
  padding: 8px 10px;
  margin-bottom: 4px;
  border-radius: 8px;
  background: var(--sia-bg-light);
  border-left: 3px solid var(--sia-accent-soft);
}
.sia-v-seg-f .sia-v-seg-time {
  font-family: monospace;
  font-size: 0.68rem;
  color: var(--sia-txt-soft);
  margin-right: 6px;
}
.sia-v-seg-f .sia-v-seg-text {
  font-size: 0.84rem;
  line-height: 1.5;
  color: var(--sia-txt);
}

.sia-v-comp-f {
  padding: 10px 12px;
  margin-bottom: 8px;
  border-radius: 10px;
  background: var(--sia-bg-light);
  border-left: 3px solid var(--sia-accent);
}
.sia-v-comp-f .sia-v-comp-head {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 6px;
  font-size: 0.72rem;
}
.sia-v-comp-f .sia-v-comp-title {
  font-weight: 600;
  color: var(--sia-txt);
  flex: 1;
}
.sia-v-comp-f .sia-v-comp-badge {
  font-size: 0.65rem;
  font-weight: 600;
  padding: 1px 8px;
  border-radius: 6px;
  background: rgba(107,91,74,0.1);
  color: var(--sia-accent);
  text-transform: uppercase;
}
.sia-v-comp-f .sia-v-comp-body {
  font-size: 0.82rem;
  line-height: 1.5;
  color: var(--sia-txt-mid);
}
.sia-v-comp-f img,
.sia-v-comp-f video {
  max-width: 100%;
  border-radius: 8px;
  margin-top: 6px;
}
.sia-v-comp-f .sia-v-media-actions {
  display: flex;
  justify-content: flex-end;
  margin-top: 6px;
}

/* ── Responsive detail ──────────────────────────────────── */
@media (max-width: 768px) {
  .sia-detail-viewer { flex-direction: column; }
  .sia-detail-left {
    padding-right: 0;
    border-right: none;
    border-bottom: 1px solid var(--sia-border-light);
    padding-bottom: 10px;
  }
  .sia-modal-front { width: 95%; max-height: 85%; }
  .sia-modal-front-header { flex-wrap: wrap; }
}

/* ── Admin settings : liste utilisateurs ────────────────── */
.sia-users-list {
  display: flex;
  flex-direction: column;
  gap: 4px;
  max-height: 320px;
  overflow-y: auto;
  padding: 8px;
  border: 1px solid #e0e0e0;
  border-radius: 6px;
  background: #fff;
}
.sia-user-item {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 4px 6px;
  border-radius: 4px;
}
.sia-user-item:hover { background: #f5f5f5; }
.sia-user-admin { opacity: 0.7; }
.sia-user-email { color: #888; font-size: 0.88em; }
.sia-user-badge {
  font-size: 0.72em;
  padding: 1px 6px;
  border-radius: 4px;
  background: #6B5B4A;
  color: #fff;
  text-transform: uppercase;
  font-weight: 600;
}
