/* ============================================================
 * magIA Chat Widget — liquid glass, flowing, no dividers
 *
 *  · System:    SecurApp Liquid Glass (variables.css tokens)
 *  · Anchor:    SecurApp brandmark — único elemento de marca
 *  · Layout:    Una sola superficie de cristal, sin separadores
 *  · Color:     Monocromo + glass tints (#3D5CE5 light / #b820e6 dark)
 *
 *  Class contract used by magia-widget.js (unchanged).
 * ============================================================ */

/* ─── Shell ─────────────────────────────────────────────── */

.magia-widget {
  position: fixed;
  inset: 0;
  z-index: 9998;
  pointer-events: none;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  font-family: 'Plus Jakarta Sans', -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
  opacity: 0;
  transition: opacity var(--duration-normal) var(--ease-smooth);
}

.magia-widget.is-open {
  pointer-events: auto;
  opacity: 1;
}

.magia-widget__scrim {
  position: absolute;
  inset: 0;
  background: rgba(15, 16, 21, 0.32);
  opacity: 0;
  transition: opacity var(--duration-slow) var(--ease-smooth);
  -webkit-backdrop-filter: blur(2px);
  backdrop-filter: blur(2px);
}

.magia-widget.is-open .magia-widget__scrim { opacity: 1; }

/* ─── Panel: one glass surface ──────────────────────────── */

.magia-widget__panel {
  position: relative;
  display: flex;
  flex-direction: column;
  width: 100%;
  max-width: 100%;
  height: 88dvh;
  max-height: 100dvh;
  border-top-left-radius: 28px;
  border-top-right-radius: 28px;
  background-color: color-mix(in srgb, #ffffff 78%, transparent);
  -webkit-backdrop-filter: var(--glass-backdrop);
  backdrop-filter: var(--glass-backdrop);
  border: 1px solid color-mix(in srgb, #0f1015 8%, transparent);
  border-bottom: none;
  box-shadow:
    0 -16px 48px -16px rgba(15, 16, 21, 0.12),
    inset 0 1px 0 rgba(255, 255, 255, 0.7);
  overflow: hidden;
  will-change: transform, opacity, filter;
  /* Apertura via @keyframes magiaPanelIn (animations.css): el panel
     arranca chico en la esquina del boton, sobrepasa ligeramente al
     70 % y se asienta — fisica de resorte tipo iOS. El cierre usa
     magiaPanelOut: salida rapida tipo "release" hacia la esquina.
     El estado por defecto (sin .is-open) reproduce magiaPanelOut
     forwards, dejando el panel en su forma final colapsada. */
  transform-origin: 100% 100%;
  animation: magiaPanelOut 180ms var(--ease-smooth) forwards;
}

.magia-widget.is-open .magia-widget__panel {
  animation: magiaPanelIn 300ms var(--ease-slide) forwards;
}


[data-theme="dark"] .magia-widget__panel {
  background-color: color-mix(in srgb, #0c0c14 72%, transparent);
  border-color: color-mix(in srgb, #ffffff 10%, transparent);
  box-shadow:
    0 -16px 48px -16px rgba(0, 0, 0, 0.5),
    inset 0 1px 0 color-mix(in srgb, #ffffff 8%, transparent);
}

@media (min-width: 1024px) {
  .magia-widget {
    align-items: flex-end;
    justify-content: flex-end;
    padding: 0 12px 24px 24px;
  }
  /* Desktop: el contenedor del widget no debe interceptar clicks fuera del
     panel — el resto de la pagina sigue navegable mientras el chat esta
     abierto. Solo el panel captura interacciones. */
  .magia-widget.is-open { pointer-events: none; }
  .magia-widget.is-open .magia-widget__panel { pointer-events: auto; }
  .magia-widget__scrim { display: none; }
  .magia-widget__panel {
    width: 400px;
    height: 620px;
    max-height: calc(100dvh - 48px);
    border-radius: 28px;
    border-bottom: 1px solid color-mix(in srgb, #0f1015 8%, transparent);
    box-shadow:
      0 32px 64px -24px rgba(15, 16, 21, 0.20),
      0 8px 24px -8px rgba(15, 16, 21, 0.08),
      inset 0 1px 0 rgba(255, 255, 255, 0.7);
    /* La animacion de apertura/cierre la maneja magiaPanelIn /
       magiaPanelOut con transform-origin 100% 100%; en desktop no
       hay overrides porque la fisica de resorte funciona igual de
       bien a 400 x 620 px que a full-width mobile. */
  }
  [data-theme="dark"] .magia-widget__panel {
    border-bottom-color: color-mix(in srgb, #ffffff 10%, transparent);
    box-shadow:
      0 32px 64px -24px rgba(0, 0, 0, 0.65),
      0 8px 24px -8px rgba(0, 0, 0, 0.4),
      inset 0 1px 0 color-mix(in srgb, #ffffff 8%, transparent);
  }
}

/* ─── Header — flows into body, no divider ──────────────── */

.magia-widget__header {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 18px 20px 12px;
  flex-shrink: 0;
}

/* The avatar IS the brand. Brandmark on its own — no plate, no border. */
.magia-widget__avatar {
  position: relative;
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.magia-widget__avatar img {
  width: 40px;
  height: 40px;
  object-fit: contain;
  display: block;
}

.magia-widget__heading { flex: 1; min-width: 0; }

.magia-widget__title {
  font-size: 15px;
  font-weight: 700;
  color: var(--text-primary);
  margin: 0;
  letter-spacing: -0.02em;
  line-height: 1.1;
}

.magia-widget__subtitle {
  font-size: 11.5px;
  color: var(--text-tertiary);
  margin: 2px 0 0;
  display: flex;
  align-items: center;
  gap: 6px;
  font-weight: 500;
  letter-spacing: -0.005em;
}

.magia-widget__subtitle::before {
  content: "";
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: #22c55e;
  box-shadow: 0 0 0 0 rgba(34, 197, 94, 0.45);
  animation: magiaOnlinePulse 2.4s var(--ease-in-out) infinite;
}

@keyframes magiaOnlinePulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(34, 197, 94, 0.45); }
  50%      { box-shadow: 0 0 0 4px rgba(34, 197, 94, 0); }
}

/* Close: mismo sistema glass que .adm-float-controls__btn del proyecto. */
.magia-widget__close {
  width: 34px;
  height: 34px;
  border: none;
  border-radius: var(--radius-lg);
  background-color: var(--glass-bg);
  -webkit-backdrop-filter: var(--glass-backdrop-soft);
  backdrop-filter: var(--glass-backdrop-soft);
  box-shadow: var(--glass-shadow);
  color: var(--text-secondary);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform var(--duration-fast) var(--ease-smooth),
              background-color var(--duration-fast) var(--ease-smooth),
              color var(--duration-fast) var(--ease-smooth);
}

.magia-widget__close:hover {
  background-color: var(--glass-bg-hover);
  color: var(--text-primary);
  transform: translateY(-1px);
}

.magia-widget__close:active { transform: translateY(0) scale(0.96); }

/* ─── Welcome / consent — generous breathing room ──────── */

.magia-widget__consent {
  padding: 32px 28px 28px;
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
  text-align: center;
  gap: 16px;
}

/* The hero — brandmark on its own, big and clean. */
.magia-widget__consent-icon {
  margin: 0 auto 4px;
  width: 104px;
  height: 104px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.magia-widget__consent-icon img {
  width: 104px;
  height: 104px;
  object-fit: contain;
  display: block;
}

.magia-widget__consent-title {
  font-size: 24px;
  font-weight: 700;
  color: var(--text-primary);
  margin: 0;
  letter-spacing: -0.03em;
  line-height: 1.15;
}

.magia-widget__consent-text {
  font-size: 13.5px;
  color: var(--text-tertiary);
  margin: 0 auto;
  line-height: 1.55;
  max-width: 30ch;
  letter-spacing: -0.005em;
}

.magia-widget__consent-text a {
  color: var(--text-primary);
  text-decoration: none;
  font-weight: 600;
  border-bottom: 1px solid currentColor;
}

.magia-widget__consent-actions {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin: 12px auto 0;
  width: 100%;
  max-width: 280px;
}

/* ─── Buttons — solid ink, no gradient ─────────────────── */

.magia-widget__btn {
  height: 44px;
  padding: 0 20px;
  border: none;
  border-radius: 999px;
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font-family: inherit;
  letter-spacing: -0.01em;
  transition: background-color var(--duration-fast) var(--ease-smooth),
              color var(--duration-fast) var(--ease-smooth),
              transform var(--duration-fast) var(--ease-spring);
}

.magia-widget__btn:active { transform: scale(0.98); }

.magia-widget__btn--primary {
  background-image: var(--gradient-fill);
  background-color: var(--gradient-active-from);
  color: #ffffff;
  box-shadow:
    0 8px 20px -8px color-mix(in srgb, var(--gradient-active-to) 60%, transparent),
    inset 0 1px 0 rgba(255, 255, 255, 0.16);
}

.magia-widget__btn--primary:hover {
  transform: translateY(-1px);
  box-shadow:
    0 12px 26px -8px color-mix(in srgb, var(--gradient-active-to) 75%, transparent),
    inset 0 1px 0 rgba(255, 255, 255, 0.22);
}

.magia-widget__btn--ghost {
  background: transparent;
  color: var(--text-tertiary);
}

.magia-widget__btn--ghost:hover {
  background-color: color-mix(in srgb, #0f1015 5%, transparent);
  color: var(--text-primary);
}

[data-theme="dark"] .magia-widget__btn--ghost:hover {
  background-color: color-mix(in srgb, #ffffff 6%, transparent);
}

/* ─── Messages list ───────────────────────────────────── */

.magia-widget__body {
  flex: 1;
  overflow-y: auto;
  overflow-x: hidden;
  padding: 10px 16px 4px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  scrollbar-width: thin;
  scrollbar-color: color-mix(in srgb, var(--text-primary) 14%, transparent) transparent;
}

.magia-widget__body::-webkit-scrollbar { width: 6px; }
.magia-widget__body::-webkit-scrollbar-thumb {
  background: color-mix(in srgb, var(--text-primary) 14%, transparent);
  border-radius: 999px;
}

.magia-widget__message {
  display: flex;
  flex-direction: column;
  max-width: 84%;
  animation: magiaMsgIn 280ms var(--ease-spring) both;
}

@keyframes magiaMsgIn {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: translateY(0); }
}

.magia-widget__message--user { align-self: flex-end; align-items: flex-end; }
.magia-widget__message--assistant,
.magia-widget__message--admin { align-self: flex-start; align-items: flex-start; }
.magia-widget__message--system { align-self: center; align-items: center; }

.magia-widget__bubble {
  padding: 9px 13px 6px;
  border-radius: 18px;
  font-size: 14px;
  line-height: 1.5;
  word-wrap: break-word;
  white-space: pre-wrap;
  letter-spacing: -0.005em;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.magia-widget__bubble-text {
  display: block;
}

.magia-widget__bubble-text strong { font-weight: 700; }
.magia-widget__bubble-text em { font-style: italic; }
.magia-widget__bubble-text code {
  font-family: 'JetBrains Mono', ui-monospace, monospace;
  font-size: 0.86em;
  padding: 1px 5px;
  border-radius: 4px;
  background: color-mix(in srgb, var(--text-primary) 8%, transparent);
}
.magia-widget__bubble-text a {
  color: inherit;
  text-decoration: underline;
  text-underline-offset: 2px;
}
.magia-widget__bubble-text ul,
.magia-widget__bubble-text ol {
  margin: 6px 0 4px;
  padding-left: 20px;
  display: flex;
  flex-direction: column;
  gap: 3px;
}
.magia-widget__bubble-text li { line-height: 1.5; }
.magia-widget__message--user .magia-widget__bubble-text code {
  background: rgba(255, 255, 255, 0.18);
}

/* Action CTAs — botones bajo la burbuja del asistente/admin, estilo
   Tidio: pills clicables que llevan al módulo, planes o /contacto sin
   ensuciar la respuesta con URLs planas. */
.magia-widget__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 8px;
  max-width: 78%;
}
.magia-widget__action {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 7px 12px;
  border-radius: 999px;
  font-size: 12.5px;
  font-weight: 600;
  line-height: 1.2;
  letter-spacing: -0.005em;
  text-decoration: none;
  cursor: pointer;
  white-space: nowrap;
  transition:
    transform var(--duration-fast) var(--ease-smooth),
    background-color var(--duration-fast) var(--ease-smooth),
    box-shadow var(--duration-fast) var(--ease-smooth),
    border-color var(--duration-fast) var(--ease-smooth);
}
.magia-widget__action::after {
  content: '→';
  font-size: 13px;
  opacity: 0.85;
  transition: transform var(--duration-fast) var(--ease-smooth);
}
.magia-widget__action:hover { transform: translateY(-1px); }
.magia-widget__action:hover::after { transform: translateX(2px); }
.magia-widget__action:active { transform: translateY(0); }

.magia-widget__action--primary {
  background-image: var(--gradient-fill);
  background-color: var(--gradient-active-from);
  color: #fff;
  border: 1px solid transparent;
  box-shadow:
    0 4px 12px -4px color-mix(in srgb, var(--gradient-active-to) 55%, transparent),
    inset 0 1px 0 rgba(255, 255, 255, 0.18);
}
.magia-widget__action--primary:hover {
  box-shadow:
    0 6px 16px -4px color-mix(in srgb, var(--gradient-active-to) 70%, transparent),
    inset 0 1px 0 rgba(255, 255, 255, 0.25);
}

.magia-widget__action--secondary {
  background-color: color-mix(in srgb, var(--text-primary) 6%, transparent);
  color: var(--text-primary);
  border: 1px solid color-mix(in srgb, var(--text-primary) 12%, transparent);
}
.magia-widget__action--secondary:hover {
  background-color: color-mix(in srgb, var(--text-primary) 10%, transparent);
  border-color: color-mix(in srgb, var(--text-primary) 18%, transparent);
}

[data-theme="dark"] .magia-widget__action--secondary {
  background-color: rgba(255, 255, 255, 0.06);
  border-color: rgba(255, 255, 255, 0.12);
  color: var(--text-primary);
}
[data-theme="dark"] .magia-widget__action--secondary:hover {
  background-color: rgba(255, 255, 255, 0.1);
  border-color: rgba(255, 255, 255, 0.2);
}

/* Date+time stamp INSIDE the bubble — small, subdued, right-aligned. */
.magia-widget__stamp {
  display: block;
  font-size: 10px;
  letter-spacing: 0.01em;
  font-variant-numeric: tabular-nums;
  line-height: 1.2;
  opacity: 0.55;
  align-self: flex-end;
  margin-top: 1px;
}

.magia-widget__message--user .magia-widget__stamp { color: rgba(255, 255, 255, 0.85); }
.magia-widget__message--assistant .magia-widget__stamp,
.magia-widget__message--admin .magia-widget__stamp { color: var(--text-muted); }

.magia-widget__message--user .magia-widget__bubble {
  background-image: var(--gradient-fill);
  background-color: var(--gradient-active-from);
  color: #ffffff;
  border-bottom-right-radius: 6px;
  box-shadow:
    0 6px 18px -6px color-mix(in srgb, var(--gradient-active-to) 55%, transparent),
    0 1px 2px color-mix(in srgb, var(--gradient-active-to) 30%, transparent),
    inset 0 1px 0 rgba(255, 255, 255, 0.18),
    inset 0 -1px 0 rgba(0, 0, 0, 0.08);
}

/* Assistant bubble: real glass — full backdrop + inset highlight */
.magia-widget__message--assistant .magia-widget__bubble {
  background-color: var(--glass-bg);
  -webkit-backdrop-filter: var(--glass-backdrop);
  backdrop-filter: var(--glass-backdrop);
  color: var(--text-primary);
  border: 1px solid color-mix(in srgb, #0f1015 7%, transparent);
  border-bottom-left-radius: 6px;
  box-shadow:
    0 4px 14px -6px rgba(15, 16, 21, 0.08),
    inset 0 1px 0 rgba(255, 255, 255, 0.55);
}

[data-theme="dark"] .magia-widget__message--assistant .magia-widget__bubble {
  border-color: color-mix(in srgb, #ffffff 10%, transparent);
  box-shadow:
    0 4px 14px -6px rgba(0, 0, 0, 0.4),
    inset 0 1px 0 color-mix(in srgb, #ffffff 8%, transparent);
}

.magia-widget__message--admin .magia-widget__bubble {
  background-color: color-mix(in srgb, #3D5CE5 8%, transparent);
  -webkit-backdrop-filter: var(--glass-backdrop);
  backdrop-filter: var(--glass-backdrop);
  color: var(--text-primary);
  border: 1px solid color-mix(in srgb, #3D5CE5 26%, transparent);
  border-bottom-left-radius: 6px;
  box-shadow:
    0 4px 14px -6px rgba(81, 112, 255, 0.18),
    inset 0 1px 0 rgba(255, 255, 255, 0.4);
}

[data-theme="dark"] .magia-widget__message--admin .magia-widget__bubble {
  background-color: color-mix(in srgb, #b820e6 12%, transparent);
  border-color: color-mix(in srgb, #b820e6 32%, transparent);
  box-shadow:
    0 4px 14px -6px rgba(206, 50, 255, 0.22),
    inset 0 1px 0 color-mix(in srgb, #ffffff 10%, transparent);
}

.magia-widget__message--admin::before {
  content: "Asesor humano";
  display: block;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-primary);
  margin: 0 0 4px 4px;
}

[data-theme="dark"] .magia-widget__message--admin::before {
  color: var(--color-secondary);
}

.magia-widget__message--system {
  align-self: center;
  max-width: 90%;
}

.magia-widget__message--system .magia-widget__bubble {
  background: transparent;
  color: var(--text-muted);
  font-size: 11.5px;
  padding: 4px 8px;
  text-align: center;
}

/* ─── Typing indicator ────────────────────────────────── */

.magia-widget__typing {
  align-self: flex-start;
  padding: 12px 14px;
  background-color: color-mix(in srgb, #ffffff 65%, transparent);
  -webkit-backdrop-filter: blur(var(--glass-blur-soft));
  backdrop-filter: blur(var(--glass-blur-soft));
  border: 1px solid color-mix(in srgb, #0f1015 6%, transparent);
  border-radius: 18px;
  border-bottom-left-radius: 6px;
  display: none;
  align-items: center;
  gap: 4px;
  margin-left: 16px;
  margin-bottom: 4px;
}

.magia-widget__typing.is-active { display: inline-flex; }

[data-theme="dark"] .magia-widget__typing {
  background-color: color-mix(in srgb, #ffffff 6%, transparent);
  border-color: color-mix(in srgb, #ffffff 10%, transparent);
}

.magia-widget__typing span {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--text-tertiary);
  animation: magiaTypingBounce 1.3s var(--ease-in-out) infinite;
}

.magia-widget__typing span:nth-child(2) { animation-delay: 0.18s; }
.magia-widget__typing span:nth-child(3) { animation-delay: 0.36s; }

@keyframes magiaTypingBounce {
  0%, 60%, 100% { opacity: 0.3; transform: translateY(0); }
  30%           { opacity: 1;   transform: translateY(-3px); }
}

/* ─── Composer — floating glass pill ──────────────────── */

.magia-widget__compose {
  display: flex;
  align-items: center;
  gap: 6px;
  margin: 4px 14px 8px;
  padding: 4px 4px 4px 14px;
  min-height: 44px;
  border: 1px solid color-mix(in srgb, #0f1015 10%, transparent);
  border-radius: 22px;
  background-color: color-mix(in srgb, #ffffff 70%, transparent);
  -webkit-backdrop-filter: blur(var(--glass-blur-soft));
  backdrop-filter: blur(var(--glass-blur-soft));
  flex-shrink: 0;
  transition: border-color var(--duration-fast) var(--ease-smooth),
              box-shadow var(--duration-normal) var(--ease-smooth);
}

.magia-widget__compose:focus-within {
  border-color: color-mix(in srgb, #0f1015 28%, transparent);
  box-shadow: 0 0 0 3px color-mix(in srgb, #0f1015 5%, transparent);
}

[data-theme="dark"] .magia-widget__compose {
  background-color: color-mix(in srgb, #ffffff 6%, transparent);
  border-color: color-mix(in srgb, #ffffff 12%, transparent);
}

[data-theme="dark"] .magia-widget__compose:focus-within {
  border-color: color-mix(in srgb, #ffffff 30%, transparent);
  box-shadow: 0 0 0 3px color-mix(in srgb, #ffffff 6%, transparent);
}

.magia-widget__input {
  flex: 1;
  resize: none;
  height: 22px;
  min-height: 22px;
  max-height: 96px;
  padding: 2px 0;
  margin: 0;
  border: none;
  background: transparent;
  color: var(--text-primary);
  font-size: 14px;
  font-family: inherit;
  line-height: 1.45;
  outline: none;
  letter-spacing: -0.005em;
  overflow-y: auto;
  display: block;
}

.magia-widget__input::placeholder { color: var(--text-muted); }
.magia-widget__input:disabled { opacity: 0.5; cursor: not-allowed; }

.magia-widget__send {
  width: 34px;
  height: 34px;
  flex-shrink: 0;
  border: none;
  border-radius: 50%;
  background-image: var(--gradient-fill);
  background-color: var(--gradient-active-from);
  color: #ffffff;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  align-self: center;
  box-shadow:
    0 6px 14px -4px color-mix(in srgb, var(--gradient-active-to) 55%, transparent),
    inset 0 1px 0 rgba(255, 255, 255, 0.18);
  transition: transform var(--duration-fast) var(--ease-spring),
              box-shadow var(--duration-fast) var(--ease-smooth),
              opacity var(--duration-fast) var(--ease-smooth);
}

.magia-widget__send svg { width: 14px; height: 14px; }

.magia-widget__send:hover:not(:disabled) {
  transform: scale(1.06);
  box-shadow:
    0 10px 22px -4px color-mix(in srgb, var(--gradient-active-to) 70%, transparent),
    inset 0 1px 0 rgba(255, 255, 255, 0.24);
}

.magia-widget__send:active:not(:disabled) { transform: scale(0.94); }

.magia-widget__send:disabled {
  opacity: 0.35;
  cursor: not-allowed;
  box-shadow: none;
}

/* ─── Footer — just text, no separator ────────────────── */

.magia-widget__footer {
  padding: 2px 20px 14px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  flex-shrink: 0;
  font-size: 11px;
  color: var(--text-muted);
}

.magia-widget__wa {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--text-tertiary);
  background: transparent;
  border: none;
  font-family: inherit;
  font-weight: 500;
  font-size: 12px;
  padding: 4px 0;
  cursor: pointer;
  letter-spacing: -0.005em;
  transition: color var(--duration-fast) var(--ease-smooth);
}

.magia-widget__wa:hover { color: var(--text-primary); }

.magia-widget__wa svg { width: 13px; height: 13px; color: #25D366; }

.magia-widget__powered {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 11.5px;
  font-weight: 500;
  letter-spacing: -0.005em;
  color: var(--text-tertiary);
}

.magia-widget__powered-label {
  opacity: 0.7;
  font-weight: 500;
}

.magia-widget__powered-logo {
  width: 13px;
  height: 13px;
  object-fit: contain;
  display: block;
}

.magia-widget__powered-brand {
  font-weight: 700;
  color: var(--text-secondary);
  letter-spacing: -0.015em;
}

/* ─── Reduced motion ──────────────────────────────────── */

@media (prefers-reduced-motion: reduce) {
  .magia-widget,
  .magia-widget__panel,
  .magia-widget__scrim,
  .magia-widget__message,
  .magia-widget__typing span,
  .magia-widget__btn,
  .magia-widget__send,
  .magia-widget__subtitle::before {
    transition: none !important;
    animation: none !important;
  }
}
