/* =========================================================
   Woospeak AI — Message / chat classical layer
   ========================================================= */

/* =========================================================
   Chat coach header / inline coach
   ========================================================= */
#woospeak-ai-app .ws-coach-header-block{
  display:flex;
  align-items:center;
  margin:0 0 6px;
  padding:4px 8px;
  border-radius:10px;
  background:rgba(99,102,241,.04);
}

#woospeak-ai-app .ws-coach-header-block.is-focus{
  background:rgba(245,158,11,.06);
}

#woospeak-ai-app .ws-coach-header-block.is-success{
  background:rgba(34,197,94,.06);
}

#woospeak-ai-app .ws-coach-header-block.is-coach{
  background:rgba(99,102,241,.06);
}

#woospeak-ai-app .ws-coach-header-block.is-error{
  background:rgba(239,68,68,.06);
}

#woospeak-ai-app .ws-coach-header-inner,
#woospeak-ai-app .ws-coach-header-topline{
  display:flex;
  align-items:center;
  gap:6px;
}

#woospeak-ai-app .ws-coach-header-copy{
  display:flex;
  align-items:center;
}

#woospeak-ai-app .ws-coach-avatar--inline{
  width:18px;
  height:18px;
  min-width:18px;
  min-height:18px;
  display:block;
  flex:0 0 auto;
  position:relative;
  overflow:hidden;
  border-radius:50%;
  border:1px solid rgba(255,255,255,.72);
  outline:1px solid rgba(99,102,241,.14);
  background:linear-gradient(135deg, #6366f1, #3b82f6);
  box-shadow:none;
  opacity:.96;
  transform:scale(1);
  transition:
    transform .18s ease,
    background .18s ease,
    outline-color .18s ease,
    opacity .18s ease;
}

#woospeak-ai-app .ws-coach-avatar--inline::before,
#woospeak-ai-app .ws-coach-avatar--inline::after{
  display:none !important;
  content:none !important;
}

#woospeak-ai-app .ws-coach-avatar--inline .ws-avatar-face{
  position:absolute;
  inset:0;
  display:block !important;
  width:100%;
  height:100%;
}

#woospeak-ai-app .ws-coach-avatar--inline .ws-eyes{
  position:absolute;
  top:5px;
  left:4px;
  right:4px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  margin:0;
}

#woospeak-ai-app .ws-coach-avatar--inline .ws-eyes span{
  display:block;
  width:2px;
  height:2px;
  border-radius:50%;
  background:#fff;
  box-shadow:none;
}

#woospeak-ai-app .ws-coach-avatar--inline .ws-mouth{
  position:absolute;
  left:50%;
  bottom:4px;
  width:6px;
  height:2px;
  transform:translateX(-50%);
  border-radius:0 0 6px 6px;
  background:#fff;
}

#woospeak-ai-app .ws-coach-avatar--inline.is-active{
  opacity:1;
  transform:scale(1.10);
}

#woospeak-ai-app .ws-coach-avatar--inline.is-focus{
  background:linear-gradient(135deg, #f59e0b, #fbbf24);
  outline:2px solid rgba(245,158,11,.26);
  animation:wsInlinePulse .45s ease;
}

#woospeak-ai-app .ws-coach-avatar--inline.is-success{
  background:linear-gradient(135deg, #22c55e, #4ade80);
  outline:2px solid rgba(34,197,94,.24);
  animation:wsInlinePop .42s ease;
}

#woospeak-ai-app .ws-coach-avatar--inline.is-coach{
  background:linear-gradient(135deg, #6366f1, #818cf8);
  outline:2px solid rgba(99,102,241,.24);
  animation:wsInlineGlow .55s ease;
}

#woospeak-ai-app .ws-coach-avatar--inline.is-error{
  background:linear-gradient(135deg, #ef4444, #f87171);
  outline:2px solid rgba(239,68,68,.24);
  animation:wsInlineShake .28s ease;
}

#woospeak-ai-app .ws-coach-avatar--inline.is-active .ws-eyes span{
  animation:wsInlineBlinkSoft 4.8s ease-in-out infinite;
}

#woospeak-ai-app .ws-coach-avatar--inline.is-speaking .ws-mouth{
  animation:wsInlineTalkingSoft .24s ease-in-out infinite alternate;
}

#woospeak-ai-app .ws-coach-avatar--inline.is-success .ws-mouth{
  width:7px;
  height:3px;
  border-radius:0 0 8px 8px;
}

#woospeak-ai-app .ws-coach-avatar--inline.is-focus .ws-eyes span{
  transform:scaleY(.82);
}

#woospeak-ai-app .ws-coach-avatar--inline.is-error .ws-mouth{
  transform:translateX(-50%) rotate(180deg);
}

#woospeak-ai-app .ws-coach-header-badge{
  display:inline-flex;
  align-items:center;
  gap:4px;
  min-height:18px;
  padding:2px 6px;
  border-radius:999px;
  font-size:10px;
  line-height:1;
  font-weight:800;
  white-space:nowrap;
  background:rgba(99,102,241,.10);
  color:#4f46e5;
}

#woospeak-ai-app .ws-coach-header-badge.is-focus{
  background:rgba(245,158,11,.14);
  color:#b45309;
}

#woospeak-ai-app .ws-coach-header-badge.is-success{
  background:rgba(34,197,94,.14);
  color:#15803d;
}

#woospeak-ai-app .ws-coach-header-badge.is-coach{
  background:rgba(99,102,241,.14);
  color:#4338ca;
}

#woospeak-ai-app .ws-coach-header-badge.is-error{
  background:rgba(239,68,68,.14);
  color:#dc2626;
}

#woospeak-ai-app .ws-coach-header-badge-ico{
  font-size:9px;
  line-height:1;
}

@keyframes wsInlinePulse{
  0%{ transform:scale(1); }
  50%{ transform:scale(1.14); }
  100%{ transform:scale(1.08); }
}

@keyframes wsInlinePop{
  0%{ transform:scale(1); }
  50%{ transform:scale(1.16); }
  100%{ transform:scale(1.08); }
}

@keyframes wsInlineGlow{
  0%{ transform:scale(1); filter:brightness(1); }
  50%{ transform:scale(1.12); filter:brightness(1.08); }
  100%{ transform:scale(1.08); filter:brightness(1); }
}

@keyframes wsInlineShake{
  0%{ transform:translateX(0); }
  25%{ transform:translateX(-1px); }
  50%{ transform:translateX(1px); }
  75%{ transform:translateX(-1px); }
  100%{ transform:translateX(0); }
}

@keyframes wsInlineBlinkSoft{
  0%, 44%, 48%, 100%{ transform:scaleY(1); opacity:1; }
  46%{ transform:scaleY(.22); opacity:.88; }
}

@keyframes wsInlineTalkingSoft{
  from{ height:2px; }
  to{ height:4px; }
}

/* =========================================================
   Chat log
   ========================================================= */
#woospeak-ai-app .woospeak-ai-chat-log{
  order:1;
  height:520px;
  min-width:0;
  overflow:auto;
  padding:14px;
  border-radius:0 0 28px 28px;
  background:
    radial-gradient(900px 340px at 18% 0%, rgba(37,99,235,.08), transparent 42%),
    radial-gradient(760px 280px at 88% 10%, rgba(129,140,248,.07), transparent 42%),
    linear-gradient(180deg, #f8fbff 0%, #f2f6fc 100%);
}

#woospeak-ai-app .woospeak-ai-chat-log::-webkit-scrollbar{
  width:10px;
}

#woospeak-ai-app .woospeak-ai-chat-log::-webkit-scrollbar-thumb{
  background:rgba(15,23,42,.18);
  border-radius:999px;
  border:3px solid rgba(255,255,255,.65);
}

/* =========================================================
   Bubbles
   ========================================================= */
#woospeak-ai-app .woospeak-ai-bubble{
  position:relative;
  display:flex;
  align-items:flex-start;
  gap:10px;
  max-width:94%;
  min-width:0;
  margin:8px 0;
  padding:12px 14px;
  border-radius:20px;
  line-height:1.40;
  font-size:14px;
  color:var(--ws-text);
  box-shadow:0 10px 24px rgba(15,23,42,.08);
  word-wrap:break-word;
  overflow-wrap:anywhere;
}

#woospeak-ai-app .woospeak-ai-user{
  margin-left:auto;
  border-top-right-radius:10px;
  background:linear-gradient(180deg, rgba(37,99,235,.18), rgba(37,99,235,.10));
  border:1px solid rgba(37,99,235,.18);
}

#woospeak-ai-app .woospeak-ai-assistant{
  margin-right:auto;
  display:flex;
  flex-direction:column;
  align-items:stretch;
  gap:8px;
  border-top-left-radius:10px;
  background:linear-gradient(180deg, rgba(255,255,255,.98), rgba(248,250,252,.95));
  border:1px solid rgba(15,23,42,.08);
}

#woospeak-ai-app .woospeak-ai-assistant::before{
  content:'';
  position:absolute;
  left:0;
  top:14px;
  bottom:14px;
  width:3px;
  border-radius:999px;
  background:linear-gradient(180deg, rgba(37,99,235,.82), rgba(129,140,248,.55));
  opacity:.9;
}

#woospeak-ai-app .woospeak-ai-assistant .ws-coach-header-block{
  width:100%;
  min-width:0;
  margin:0 0 2px;
}

#woospeak-ai-app .woospeak-ai-meta{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:24px;
  height:24px;
  padding:0 6px;
  flex:0 0 auto;
  border-radius:999px;
  background:rgba(15,23,42,.06);
  border:1px solid rgba(15,23,42,.10);
  color:rgba(15,23,42,.88);
  font-size:14px;
  line-height:1;
  transform:translateY(1px);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.68);
}

#woospeak-ai-app .woospeak-ai-bubble-content{
  flex:1 1 auto;
  min-width:0;
  width:100%;
  display:flex;
  flex-direction:column;
  gap:3px;
}

#woospeak-ai-app .woospeak-ai-line{
  display:grid;
  grid-template-columns:28px minmax(0,1fr) 42px;
  gap:10px;
  align-items:start;
  min-width:0;
}

#woospeak-ai-app .woospeak-ai-line-label{
  width:28px;
  height:22px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  font-size:13px;
  line-height:1;
  background:rgba(15,23,42,.04);
  border:1px solid rgba(15,23,42,.08);
  transform:translateY(1px);
}

#woospeak-ai-app .woospeak-ai-line-text{
  min-width:0;
  line-height:1.38;
  overflow-wrap:anywhere;
}

#woospeak-ai-app .woospeak-ai-line-text strong{
  font-weight:900;
}

#woospeak-ai-app .woospeak-ai-line-actions{
  position:relative;
  z-index:5;
  display:flex;
  align-items:flex-start;
  justify-content:flex-end;
  gap:8px;
  width:42px;
  min-width:42px;
  flex:0 0 auto;
}

#woospeak-ai-app .woospeak-ai-assistant-en{
  font-weight:780;
}

#woospeak-ai-app .woospeak-ai-assistant-fr,
#woospeak-ai-app .woospeak-ai-assistant-correction-fr{
  margin-top:0 !important;
  opacity:.84;
  font-size:13px;
}

/* EN assistant row with audio controls */
#woospeak-ai-app .woospeak-ai-line.woospeak-ai-assistant-en{
  grid-template-columns:28px minmax(0,1fr) 42px;
  align-items:start;
}

#woospeak-ai-app .woospeak-ai-line.woospeak-ai-assistant-en .woospeak-ai-line-text{
  padding-top:2px;
}

/* Correction row stays text-only */
#woospeak-ai-app .woospeak-ai-line.woospeak-ai-assistant-en.woospeak-ai-assistant-correction{
  grid-template-columns:28px minmax(0,1fr);
}

#woospeak-ai-app .woospeak-ai-line.woospeak-ai-assistant-en.woospeak-ai-assistant-correction .woospeak-ai-line-actions{
  display:none;
}

/* =========================================================
   Message feedback highlights
   ========================================================= */
#woospeak-ai-app .ws-highlight-error{
  background:rgba(255,80,80,.15);
  border-bottom:2px solid rgba(255,80,80,.6);
  animation:wsFeedbackPulse .8s ease;
}

#woospeak-ai-app .ws-highlight-correct{
  background:rgba(80,200,120,.15);
  border-bottom:2px solid rgba(80,200,120,.6);
}

@keyframes wsFeedbackPulse{
  0%{ background:rgba(255,80,80,.30); }
  100%{ background:rgba(255,80,80,.15); }
}

/* =========================================================
   TTS buttons
   ========================================================= */
#woospeak-ai-app .woospeak-ai-line-speak,
#woospeak-ai-app .woospeak-ai-drill-tts,
#woospeak-ai-app .woospeak-ai-tts-inline,
#woospeak-ai-app .ws-card-speak{
  position:relative;
  z-index:6;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  flex:0 0 auto;
  width:34px;
  height:34px;
  padding:0;
  border-radius:14px;
  border:1px solid rgba(15,23,42,.10);
  background:linear-gradient(180deg, rgba(255,255,255,.96), rgba(248,250,252,.94));
  box-shadow:0 10px 22px rgba(15,23,42,.08);
  cursor:pointer;
  user-select:none;
  line-height:1;
  font-size:16px;
  transition:transform .12s ease, box-shadow .14s ease, border-color .14s ease, filter .14s ease;
}

#woospeak-ai-app .woospeak-ai-line-speak:hover,
#woospeak-ai-app .woospeak-ai-drill-tts:hover,
#woospeak-ai-app .woospeak-ai-tts-inline:hover,
#woospeak-ai-app .ws-card-speak:hover{
  transform:translateY(-1px);
  box-shadow:0 14px 28px rgba(15,23,42,.12);
  border-color:rgba(37,99,235,.24);
}

#woospeak-ai-app .woospeak-ai-line-speak:focus-visible,
#woospeak-ai-app .woospeak-ai-drill-tts:focus-visible,
#woospeak-ai-app .woospeak-ai-tts-inline:focus-visible,
#woospeak-ai-app .ws-card-speak:focus-visible{
  outline:none;
  box-shadow:var(--ws-ring), 0 16px 34px rgba(15,23,42,.16);
}

/* =========================================================
   Composer
   ========================================================= */
#woospeak-ai-app .woospeak-ai-input{
  order:2;
  position:relative;
  z-index:2;
  display:flex;
  flex-direction:column;
  gap:10px;
  padding:12px 14px;
  border-top:1px solid rgba(15,23,42,.08);
  background:linear-gradient(180deg, rgba(255,255,255,.84), rgba(255,255,255,.76));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.72);
}

#woospeak-ai-app textarea,
#woospeak-ai-app #woospeak-ai-message{
  width:100%;
  min-width:0;
  height:64px;
  min-height:64px;
  max-height:140px;
  margin:0;
  padding:14px 16px;
  resize:none;
  border-radius:18px;
  border:1px solid rgba(15,23,42,.14);
  background:linear-gradient(180deg, rgba(255,255,255,.98), rgba(248,250,252,.96));
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.78),
    0 8px 18px rgba(15,23,42,.04);
  outline:none;
  font-size:15px;
  line-height:1.32;
  transition:border-color .15s ease, box-shadow .15s ease, background .15s ease;
}

#woospeak-ai-app textarea::placeholder,
#woospeak-ai-app #woospeak-ai-message::placeholder{
  color:rgba(15,23,42,.42);
}

#woospeak-ai-app textarea:focus,
#woospeak-ai-app #woospeak-ai-message:focus{
  border-color:rgba(37,99,235,.34);
  box-shadow:
    0 0 0 4px rgba(37,99,235,.10),
    0 10px 24px rgba(15,23,42,.06);
}

#woospeak-ai-app .woospeak-ai-actions{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(0,1fr);
  grid-template-areas:
    "chat mic"
    "simulation simulation";
  gap:10px;
  width:100%;
  align-items:start;
}

#woospeak-ai-app #woospeak-ai-send{
  grid-area:chat;
  width:100%;
  min-width:0;
  height:46px;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:0 14px;
  border-radius:14px;
  border-color:rgba(37,99,235,.35);
  color:#fff;
  font-size:14px;
  font-weight:800;
  background:linear-gradient(135deg, var(--ws-primary), var(--ws-primary-2));
  box-shadow:0 18px 42px rgba(37,99,235,.24);
}

#woospeak-ai-app #woospeak-ai-send:disabled{
  opacity:1;
  color:#fff;
  -webkit-text-fill-color:#fff;
  filter:saturate(.88) brightness(.96);
}

#woospeak-ai-app .woospeak-ai-mic-stack{
  grid-area:mic;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
  width:100%;
  min-width:0;
}

#woospeak-ai-app #woospeak-ai-mic-en,
#woospeak-ai-app #woospeak-ai-mic-fr{
  width:100%;
  min-width:0;
  max-width:none;
  height:46px;
  padding:0 12px;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:6px;
  white-space:nowrap;
  font-size:15px;
  line-height:1;
  border-radius:14px;
  border:1px solid rgba(15,23,42,.10);
  background:linear-gradient(180deg, rgba(255,255,255,.98), rgba(248,250,252,.94));
  box-shadow:0 6px 16px rgba(15,23,42,.07);
}

#woospeak-ai-app #woospeak-ai-mic-en:hover,
#woospeak-ai-app #woospeak-ai-mic-fr:hover{
  transform:translateY(-1px);
  border-color:rgba(37,99,235,.18);
  box-shadow:0 10px 18px rgba(15,23,42,.10);
}

#woospeak-ai-app #woospeak-ai-mic-en.is-active-lang,
#woospeak-ai-app #woospeak-ai-mic-fr.is-active-lang{
  border-color:rgba(37,99,235,.28);
  background:linear-gradient(180deg, rgba(239,246,255,.98), rgba(219,234,254,.94));
  box-shadow:
    0 0 0 3px rgba(37,99,235,.10),
    0 8px 18px rgba(37,99,235,.10);
}

#woospeak-ai-app #woospeak-ai-mic-en .woospeak-ai-mic-ico,
#woospeak-ai-app #woospeak-ai-mic-fr .woospeak-ai-mic-ico{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  flex:0 0 auto;
  font-size:13px;
  line-height:1;
}

#woospeak-ai-app #woospeak-ai-mic-en .woospeak-ai-mic-text,
#woospeak-ai-app #woospeak-ai-mic-fr .woospeak-ai-mic-text{
  display:inline-block;
  white-space:nowrap;
  font-size:15px;
  font-weight:800;
  line-height:1;
  color:#1f2937;
  letter-spacing:.01em;
}

#woospeak-ai-app #woospeak-ai-simulation-trigger{
  grid-area:simulation;
  width:100%;
  min-width:0;
  min-height:46px;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:0 14px;
  border-radius:14px;
}

#woospeak-ai-app .woospeak-ai-btn{
  appearance:none;
  border-radius:14px;
  border:1px solid rgba(15,23,42,.16);
  padding:10px 12px;
  cursor:pointer;
  background:rgba(255,255,255,.92);
  box-shadow:0 10px 26px rgba(15,23,42,.08);
  transition:transform .12s ease, box-shadow .14s ease, border-color .14s ease, filter .14s ease;
  user-select:none;
}

#woospeak-ai-app .woospeak-ai-btn:hover{
  transform:translateY(-1px);
  box-shadow:0 14px 34px rgba(15,23,42,.12);
  border-color:rgba(15,23,42,.22);
}

#woospeak-ai-app .woospeak-ai-btn:focus-visible{
  outline:none;
  box-shadow:var(--ws-ring), 0 14px 34px rgba(15,23,42,.12);
  border-color:rgba(37,99,235,.45);
}

#woospeak-ai-app .woospeak-ai-btn:disabled{
  opacity:1;
  cursor:not-allowed;
  transform:none;
  box-shadow:0 8px 18px rgba(15,23,42,.06);
}

/* =========================================================
   Status
   ========================================================= */
#woospeak-ai-app .woospeak-ai-status{
  order:3;
  width:100%;
  grid-column:1 / -1;
  margin:4px 0 0;
  min-height:18px;
  padding:6px 12px 0;
  color:var(--ws-muted);
  font-size:12.5px;
  opacity:.78;
}

#woospeak-ai-app .woospeak-ai-status:empty{
  display:none;
  padding:0;
  min-height:0;
}

/* =========================================================
   Inline voice toggle inside assistant speaker controls
   ========================================================= */
#woospeak-ai-app .ws-inline-audio-controls{
  display:inline-flex;
  flex-direction:column;
  align-items:center;
  justify-content:flex-start;
  gap:6px;
  flex-wrap:nowrap;
  width:42px;
  min-width:42px;
  position:relative;
  z-index:5;
}

#woospeak-ai-app .ws-inline-voice-toggle{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:4px;
  width:42px;
  padding:2px;
  border-radius:14px;
  background:rgba(15,23,42,.04);
  border:1px solid rgba(15,23,42,.08);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.72);
  position:relative;
  z-index:6;
  pointer-events:auto;
}

#woospeak-ai-app .ws-inline-voice-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:17px;
  height:17px;
  min-width:17px;
  min-height:17px;
  margin:0;
  padding:0;
  appearance:none;
  -webkit-appearance:none;
  border:none;
  border-radius:999px;
  background:transparent;
  box-shadow:none;
  cursor:pointer;
  font-size:11px;
  line-height:1;
  color:#1f2937;
  position:relative;
  z-index:7;
  pointer-events:auto;
  transition:
    transform .16s ease,
    background-color .16s ease,
    color .16s ease,
    box-shadow .16s ease,
    opacity .16s ease;
}

#woospeak-ai-app .ws-inline-voice-btn:hover{
  background:rgba(37,99,235,.08);
  box-shadow:none;
  transform:translateY(-1px);
}

#woospeak-ai-app .ws-inline-voice-btn:focus-visible{
  outline:none;
  box-shadow:0 0 0 3px rgba(37,99,235,.12);
}

#woospeak-ai-app .ws-inline-voice-btn.is-active{
  background:linear-gradient(180deg, rgba(239,246,255,.98), rgba(219,234,254,.94));
  box-shadow:inset 0 0 0 1px rgba(37,99,235,.18);
  color:#1746a2;
  transform:none;
}

#woospeak-ai-app .ws-inline-voice-btn.is-active:hover{
  background:linear-gradient(180deg, rgba(239,246,255,.98), rgba(219,234,254,.94));
  color:#1746a2;
}
#woospeak-ai-app .ws-inline-voice-btn{
  transform:none !important;
}

#woospeak-ai-app .ws-inline-voice-btn:hover{
  background:rgba(37,99,235,.08);
  box-shadow:none;
}

/* Legacy temporary row forcibly hidden */
#woospeak-ai-app .ws-inline-voice-row{
  display:none !important;
}

/* =========================================================
   Keep desktop layout stable: chat left / card right
   ========================================================= */
#woospeak-ai-app .woospeak-ai-chat{
  min-width:0;
}

#woospeak-ai-app .woospeak-ai-card{
  min-width:0;
  align-self:start;
}

#woospeak-ai-app .woospeak-ai-card-inner{
  width:100%;
}

/* =========================================================
   Responsive — message layer
   ========================================================= */
@media (max-width:980px){
  #woospeak-ai-app .woospeak-ai-chat{
    order:1;
    border-radius:22px;
  }

  #woospeak-ai-app .woospeak-ai-chat-log{
    height:380px;
    padding:12px;
    border-radius:0 0 22px 22px;
  }

  #woospeak-ai-app .woospeak-ai-bubble{
    max-width:100%;
    box-shadow:0 8px 20px rgba(15,23,42,.08);
  }

  #woospeak-ai-app .woospeak-ai-line{
    grid-template-columns:24px minmax(0,1fr) 40px;
    gap:8px;
  }

  #woospeak-ai-app .woospeak-ai-line.woospeak-ai-assistant-en{
    grid-template-columns:24px minmax(0,1fr) 40px;
  }

  #woospeak-ai-app .woospeak-ai-line.woospeak-ai-assistant-en.woospeak-ai-assistant-correction{
    grid-template-columns:24px minmax(0,1fr);
  }

  #woospeak-ai-app .woospeak-ai-line-actions,
  #woospeak-ai-app .ws-inline-audio-controls,
  #woospeak-ai-app .ws-inline-voice-toggle{
    width:40px;
    min-width:40px;
  }
}

@media (max-width:640px){
  #woospeak-ai-app .woospeak-ai-chat,
  #woospeak-ai-app .woospeak-ai-card-empty--framed{
    border-radius:18px;
  }

  #woospeak-ai-app .woospeak-ai-chat-log{
    height:340px;
    padding:10px;
    border-radius:0 0 18px 18px;
  }

  #woospeak-ai-app .woospeak-ai-bubble{
    max-width:100%;
    margin:8px 0;
    padding:10px 10px 9px;
    border-radius:16px;
    font-size:13.5px;
    box-shadow:0 6px 14px rgba(15,23,42,.07);
  }

  #woospeak-ai-app .woospeak-ai-line{
    grid-template-columns:22px minmax(0,1fr) 38px;
    gap:6px;
  }

  #woospeak-ai-app .woospeak-ai-line.woospeak-ai-assistant-en{
    grid-template-columns:22px minmax(0,1fr) 38px;
  }

  #woospeak-ai-app .woospeak-ai-line.woospeak-ai-assistant-en.woospeak-ai-assistant-correction{
    grid-template-columns:22px minmax(0,1fr);
  }

  #woospeak-ai-app .woospeak-ai-line-label{
    width:22px;
    height:20px;
    font-size:12px;
  }

  #woospeak-ai-app .woospeak-ai-line-text{
    font-size:13.25px;
    line-height:1.34;
  }

  #woospeak-ai-app .woospeak-ai-assistant-fr{
    font-size:12.25px;
    opacity:.82;
  }

  #woospeak-ai-app .woospeak-ai-line-speak,
  #woospeak-ai-app .woospeak-ai-drill-tts,
  #woospeak-ai-app .woospeak-ai-tts-inline,
  #woospeak-ai-app .ws-card-speak{
    width:32px;
    height:32px;
    border-radius:12px;
    font-size:15px;
  }

  #woospeak-ai-app .woospeak-ai-input{
    gap:8px;
    padding:10px;
  }

  #woospeak-ai-app #woospeak-ai-message,
  #woospeak-ai-app textarea{
    min-height:56px;
    height:56px;
    max-height:140px;
    font-size:16px;
    line-height:1.3;
    border-radius:14px;
  }

  #woospeak-ai-app .woospeak-ai-actions{
    grid-template-columns:1fr;
    grid-template-areas:
      "chat"
      "simulation"
      "mic";
    gap:10px;
  }

  #woospeak-ai-app .woospeak-ai-mic-stack{
    grid-template-columns:1fr 1fr;
    gap:10px;
  }

  #woospeak-ai-app #woospeak-ai-send,
  #woospeak-ai-app #woospeak-ai-simulation-trigger,
  #woospeak-ai-app #woospeak-ai-mic-en,
  #woospeak-ai-app #woospeak-ai-mic-fr{
    width:100%;
    min-width:0;
    max-width:none;
    height:46px;
    padding:0 12px;
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:15px;
    line-height:1;
    border-radius:14px;
  }

  #woospeak-ai-app .woospeak-ai-status{
    font-size:11.5px;
    padding:4px 10px;
  }

  #woospeak-ai-app .woospeak-ai-line-actions,
  #woospeak-ai-app .ws-inline-audio-controls,
  #woospeak-ai-app .ws-inline-voice-toggle{
    width:38px;
    min-width:38px;
  }

  #woospeak-ai-app .ws-inline-audio-controls{
    gap:4px;
  }
}

@media (max-width:420px){
  #woospeak-ai-app .woospeak-ai-chat-log{
    height:300px;
  }

  #woospeak-ai-app .woospeak-ai-bubble{
    font-size:13px;
  }

  #woospeak-ai-app .woospeak-ai-line-text{
    font-size:12.75px;
  }

  #woospeak-ai-app .woospeak-ai-assistant-fr{
    font-size:12px;
  }

  #woospeak-ai-app .woospeak-ai-actions{
    grid-template-columns:1fr;
  }

  #woospeak-ai-app .woospeak-ai-mic-stack{
    grid-template-columns:1fr;
  }
}

@media (max-width:900px) and (orientation:landscape){
  #woospeak-ai-app .woospeak-ai-chat-log{
    height:260px;
  }
}

/* =========================================================
   Unified inline voice toggle — classic + simulation
   Premium shared version
   ========================================================= */

#woospeak-ai-app .ws-inline-voice-toggle,
#woospeak-ai-app .ws-inline-voice-toggle--simulation{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:4px;
  width:42px;
  padding:2px;
  border-radius:14px;
  background:linear-gradient(180deg, rgba(255,255,255,.78), rgba(248,250,252,.68));
  border:1px solid rgba(15,23,42,.08);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.78),
    0 4px 12px rgba(15,23,42,.06);
  position:relative;
  z-index:6;
  pointer-events:auto;
}

#woospeak-ai-app .ws-inline-voice-toggle .ws-inline-voice-btn,
#woospeak-ai-app .ws-inline-voice-toggle--simulation .ws-inline-voice-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:17px;
  height:17px;
  min-width:17px;
  min-height:17px;
  margin:0;
  padding:0;
  appearance:none;
  -webkit-appearance:none;
  border:none;
  border-radius:999px;
  background:transparent;
  box-shadow:none;
  cursor:pointer;
  font-size:11px;
  line-height:1;
  color:#1f2937;
  position:relative;
  z-index:7;
  pointer-events:auto;
  transform:none !important;
  transition:
    background-color .16s ease,
    color .16s ease,
    box-shadow .16s ease,
    opacity .16s ease,
    transform .16s ease;
}

#woospeak-ai-app .ws-inline-voice-toggle .ws-inline-voice-btn:hover,
#woospeak-ai-app .ws-inline-voice-toggle--simulation .ws-inline-voice-btn:hover{
  background:rgba(37,99,235,.08);
  box-shadow:none;
}

#woospeak-ai-app .ws-inline-voice-toggle .ws-inline-voice-btn:focus-visible,
#woospeak-ai-app .ws-inline-voice-toggle--simulation .ws-inline-voice-btn:focus-visible{
  outline:none;
  box-shadow:0 0 0 3px rgba(37,99,235,.12);
}

#woospeak-ai-app .ws-inline-voice-toggle .ws-inline-voice-btn.is-active,
#woospeak-ai-app .ws-inline-voice-toggle--simulation .ws-inline-voice-btn.is-active{
  background:linear-gradient(180deg, rgba(239,246,255,.98), rgba(219,234,254,.94));
  color:#1746a2;
  box-shadow:
    inset 0 0 0 1px rgba(37,99,235,.18),
    0 0 0 2px rgba(37,99,235,.10),
    0 4px 10px rgba(37,99,235,.16);
}

#woospeak-ai-app .ws-inline-voice-toggle .ws-inline-voice-btn.is-active::after,
#woospeak-ai-app .ws-inline-voice-toggle--simulation .ws-inline-voice-btn.is-active::after{
  content:'';
  position:absolute;
  inset:-2px;
  border-radius:999px;
  border:1px solid rgba(96,165,250,.32);
  pointer-events:none;
}

#woospeak-ai-app .ws-inline-voice-toggle .ws-inline-voice-btn.is-active:hover,
#woospeak-ai-app .ws-inline-voice-toggle--simulation .ws-inline-voice-btn.is-active:hover{
  background:linear-gradient(180deg, rgba(239,246,255,.98), rgba(219,234,254,.94));
  color:#1746a2;
}
/* =========================================================
   Chat classique — EN/FR spacing fix
   Sortir les contrôles audio du flux pour éviter le trou
   ========================================================= */

#woospeak-ai-app .woospeak-ai-line.woospeak-ai-assistant-en{
  position:relative;
  grid-template-columns:28px minmax(0,1fr);
  align-items:start;
  margin-bottom:0;
}

#woospeak-ai-app .woospeak-ai-line.woospeak-ai-assistant-en .woospeak-ai-line-text{
  min-width:0;
  padding-top:1px;
  padding-right:56px;
}

#woospeak-ai-app .woospeak-ai-line.woospeak-ai-assistant-en{
  position:relative;
}

#woospeak-ai-app .woospeak-ai-line.woospeak-ai-assistant-en .woospeak-ai-line-actions{
  position:absolute;
  top:50%;
  right:0;
  transform:translateY(-50%);
  width:42px;
  min-width:42px;
  display:flex;
  align-items:center;
  justify-content:flex-end;
  z-index:5;
}

#woospeak-ai-app .woospeak-ai-bubble-content{
  gap:2px;
}

#woospeak-ai-app .woospeak-ai-line.woospeak-ai-assistant-fr{
  margin-top:-2px;
}
#woospeak-ai-app .woospeak-ai-assistant{
  overflow:visible;
}

#woospeak-ai-app .woospeak-ai-bubble.woospeak-ai-assistant{
  padding-top:10px;
  padding-bottom:10px;
}
@media (max-width:640px){
  #woospeak-ai-app .woospeak-ai-line.woospeak-ai-assistant-en .woospeak-ai-line-actions{
    top:1px;
    width:38px;
    min-width:38px;
  }

  #woospeak-ai-app .woospeak-ai-line.woospeak-ai-assistant-en .woospeak-ai-line-text{
    padding-right:50px;
  }
}
/* =========================================================
   Classic chat — interaction style
   ========================================================= */
#woospeak-ai-app .woospeak-ai-assistant.ws-interaction-style-coach{
  border-color: rgba(37,99,235,.16);
  box-shadow:
    0 12px 28px rgba(15,23,42,.08),
    0 0 0 1px rgba(37,99,235,.06);
}

#woospeak-ai-app .woospeak-ai-assistant.ws-interaction-style-coach::before{
  background: linear-gradient(180deg, rgba(37,99,235,.92), rgba(96,165,250,.68));
  width: 4px;
}

#woospeak-ai-app .woospeak-ai-assistant.ws-interaction-style-fluid{
  border-color: rgba(15,23,42,.08);
}

#woospeak-ai-app .woospeak-ai-assistant.ws-interaction-style-coach .ws-coach-header-block{
  background: linear-gradient(180deg, rgba(239,246,255,.92), rgba(219,234,254,.68));
  border: 1px solid rgba(37,99,235,.10);
}

/* FR delayed appearance */
.ws-fr-delayed {
  opacity: 0;
  transform: translateY(4px);
  transition: opacity 0.25s ease, transform 0.25s ease;
}

.ws-fr-delayed.is-visible {
  opacity: 1;
  transform: translateY(0);
}