/* ============================================================
   AI Companion — Mico-inspired warm pebble character
   Refined, Pixar-quality. Calm presence, not childish.
   z-index: 9900 (below toasts at 9999)
   ============================================================ */

/* ── Blob container ────────────────────────────────────── */
.companion-blob {
  position: fixed;
  bottom: 24px;
  right: 24px;
  width: 68px;
  height: 68px;
  z-index: 9900;
  cursor: pointer;
  border: none;
  background: none;
  padding: 0;
  outline: none;
  -webkit-tap-highlight-color: transparent;
  transition: opacity 0.5s ease, transform 0.5s cubic-bezier(0.25, 1, 0.5, 1), filter 0.5s ease;
  filter: drop-shadow(0 2px 8px rgba(180,130,80,0.18))
          drop-shadow(0 8px 24px rgba(180,130,80,0.10));
}
.companion-blob:hover {
  transform: scale(1.06);
  filter: drop-shadow(0 2px 10px rgba(220,170,100,0.28))
          drop-shadow(0 10px 30px rgba(180,130,80,0.14));
}
.companion-blob--hidden {
  opacity: 0;
  pointer-events: none;
  transform: scale(0.5) translateY(12px);
}

/* ── Blob SVG body ─────────────────────────────────────── */
.companion-blob__svg {
  width: 100%;
  height: 100%;
  overflow: visible;
}
.companion-blob__body {
  transform-origin: 50% 52%;
}

/* ── Idle breathing — barely perceptible living warmth ─── */
.companion-blob__body {
  animation: blob-breathe 6s ease-in-out infinite;
}
@keyframes blob-breathe {
  0%, 100% { transform: scaleX(1) scaleY(1) rotate(0deg); }
  30%      { transform: scaleX(1.012) scaleY(0.988) rotate(-0.3deg); }
  60%      { transform: scaleX(0.990) scaleY(1.010) rotate(0.2deg); }
  85%      { transform: scaleX(1.005) scaleY(0.995) rotate(-0.1deg); }
}

/* ── Idle float — slow, dreamy vertical drift ──────────── */
.companion-blob__svg {
  animation: blob-float 8s ease-in-out infinite;
}
@keyframes blob-float {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(-2.5px); }
}

/* ── Ambient glow pulse — subtle luminescence ──────────── */
.companion-blob__glow {
  animation: glow-pulse 5s ease-in-out infinite;
}
@keyframes glow-pulse {
  0%, 100% { opacity: 0.25; }
  50%      { opacity: 0.45; }
}

/* ── Sparkle twinkle ───────────────────────────────────── */
.companion-blob__sparkle {
  animation: sparkle-twinkle 3s ease-in-out infinite;
  transform-origin: center;
}
.companion-blob__sparkle:nth-child(2) { animation-delay: -1s; }
.companion-blob__sparkle:nth-child(3) { animation-delay: -2s; }
@keyframes sparkle-twinkle {
  0%, 100% { opacity: 0; transform: scale(0.5); }
  50%      { opacity: 0.7; transform: scale(1); }
}

/* ── Pudding jiggle — soft, organic wobble on click ────── */
.companion-blob--jiggle .companion-blob__body {
  animation: blob-pudding 0.7s cubic-bezier(0.36, 0.07, 0.19, 0.97);
}
@keyframes blob-pudding {
  0%   { transform: scaleX(1) scaleY(1); }
  12%  { transform: scaleX(1.08) scaleY(0.92); }
  24%  { transform: scaleX(0.94) scaleY(1.06); }
  36%  { transform: scaleX(1.04) scaleY(0.96); }
  50%  { transform: scaleX(0.98) scaleY(1.02); }
  65%  { transform: scaleX(1.015) scaleY(0.985); }
  80%  { transform: scaleX(0.995) scaleY(1.005); }
  100% { transform: scaleX(1) scaleY(1); }
}

/* ── Inside Out color transitions ──────────────────────── */
.companion-blob__stop {
  transition: stop-color 0.5s ease;
}
/* BUG-006: duplicate .companion-blob transition removed — consolidated into main rule above */

/* ── Eyes ───────────────────────────────────────────────── */
.companion-blob__pupil {
  transition: transform 0.18s ease-out;
}
.companion-blob__mouth {
  /* d transition removed — only works in Chromium, snaps on Firefox/Safari */
}
.companion-blob__brow {
  /* BUG-005: removed transition: d — Chromium-only, snaps on Firefox/Safari */
  transition: opacity 0.3s ease;
}

/* ── Blink — driven by JS with asymmetric timing ────────── */
.companion-blob__eye-white {
  transform-origin: 50% 50%;
  transform-box: fill-box;
}

/* ── Has-message indicator — body turns blue ─────────── */
.companion-blob--has-suggestion .companion-blob__stop:nth-child(1) { stop-color: #eef2ff; }
.companion-blob--has-suggestion .companion-blob__stop:nth-child(2) { stop-color: #d8e2f6; }
.companion-blob--has-suggestion .companion-blob__stop:nth-child(3) { stop-color: #b4c6e6; }
.companion-blob--has-suggestion .companion-blob__stop:nth-child(4) { stop-color: #96aed4; }
.companion-blob--has-suggestion {
  animation: blob-glow-ring 2.5s ease-in-out infinite;
  filter: drop-shadow(0 2px 8px rgba(120,140,200,0.18))
          drop-shadow(0 8px 24px rgba(120,140,200,0.12));
}
@keyframes blob-glow-ring {
  0%, 100% { filter: drop-shadow(0 2px 8px rgba(120,140,200,0.18))
                     drop-shadow(0 8px 24px rgba(120,140,200,0.12))
                     drop-shadow(0 0 0 transparent); }
  50%      { filter: drop-shadow(0 2px 8px rgba(120,140,200,0.18))
                     drop-shadow(0 8px 24px rgba(120,140,200,0.12))
                     drop-shadow(0 0 14px rgba(120,160,230,0.35)); }
}
.companion-blob--has-suggestion:hover {
  animation: none;
  filter: drop-shadow(0 2px 10px rgba(120,140,200,0.24))
          drop-shadow(0 10px 30px rgba(120,140,200,0.16))
          drop-shadow(0 0 16px rgba(120,160,230,0.45));
}

/* ── Micro-nudge — single "ahem" on new detection ──────── */
.companion-blob--nudge {
  animation: blob-nudge 0.3s cubic-bezier(0.36, 0.07, 0.19, 0.97);
}
@keyframes blob-nudge {
  0%   { transform: translateX(0); }
  30%  { transform: translateX(-4px); }
  100% { transform: translateX(0); }
}
/* ── Badge counter (action count on blob) ──────────────── */
.companion-blob__badge {
  position: absolute;
  top: -2px;
  right: -2px;
  min-width: 18px;
  height: 18px;
  border-radius: 9px;
  background: var(--color-primary, #696cff);
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 4px;
  line-height: 1;
  pointer-events: none;
  box-shadow: 0 1px 4px rgba(0,0,0,0.15);
  transform: scale(0);
  transition: transform 0.2s cubic-bezier(0.34, 1.56, 0.64, 1);
}
.companion-blob__badge--visible {
  transform: scale(1);
}
.companion-blob__badge:empty {
  display: none;
}

/* ── Panel (expanded state) — warm glass morphism ────── */
.companion-panel {
  position: fixed;
  bottom: 104px;
  right: 24px;
  width: 300px;
  max-width: calc(100vw - 48px);
  max-height: 400px;
  background: #fffcf8;
  border-radius: 20px;
  border: 1px solid rgba(245, 220, 190, 0.45);
  box-shadow: 0 4px 24px rgba(180, 130, 80, 0.08),
              0 1px 3px rgba(180, 130, 80, 0.04);
  z-index: 9901;
  display: none;
  flex-direction: column;
  overflow: hidden;
  transform-origin: bottom right;
}
.companion-panel--open {
  display: flex;
  animation: panel-appear 0.35s cubic-bezier(0.25, 1, 0.5, 1);
}
@keyframes panel-appear {
  from { opacity: 0; transform: translateY(8px) scale(0.96); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}
.companion-panel--closing {
  animation: panel-disappear 0.2s ease-in forwards;
}
@keyframes panel-disappear {
  from { opacity: 1; transform: translateY(0) scale(1); }
  to   { opacity: 0; transform: translateY(6px) scale(0.97); }
}

/* ── Panel body ────────────────────────────────────────── */
.companion-body {
  padding: 14px 14px 2px;
  overflow-y: auto;
  flex: 1;
}

/* Empty state */
.companion-empty {
  padding: 24px 14px;
  text-align: center;
  color: #7a6e62;
  font-size: 12.5px;
  line-height: 1.65;
  letter-spacing: 0.01em;
}
/* ── Contextual action card — white ────────────────────── */
.companion-ctx-action {
  padding: 12px 14px;
  border-radius: 14px;
  background: #ffffff;
  border: 1px solid rgba(230, 220, 210, 0.3);
  margin-bottom: 8px;
}
.companion-ctx-action:last-child { margin-bottom: 0; }
.companion-ctx-action__text {
  font-size: 12.5px;
  color: #6a5a4a;
  line-height: 1.6;
  margin-bottom: 10px;
  letter-spacing: 0.005em;
}
.companion-ctx-action__btn {
  font-size: 11.5px;
  padding: 6px 18px;
  border-radius: 20px;
  border: none;
  cursor: pointer;
  font-weight: 600;
  background: linear-gradient(135deg, #fdd9b5 0%, #f5c8a0 100%);
  color: #6a4a2a;
  letter-spacing: 0.01em;
  transition: transform 0.15s, box-shadow 0.2s, background 0.2s;
  box-shadow: 0 1px 4px rgba(200, 150, 80, 0.12);
}
.companion-ctx-action__btn:hover {
  background: linear-gradient(135deg, #fcc8a0 0%, #f0b888 100%);
  box-shadow: 0 2px 8px rgba(200, 150, 80, 0.18);
}
.companion-ctx-action__btn:active { transform: scale(0.96); }
.companion-ctx-action__btn--dismiss {
  background: none;
  color: #9a9a9a;
  font-size: 11.5px;
  padding: 6px 12px;
  border: none;
  cursor: pointer;
  font-weight: 500;
  letter-spacing: 0.01em;
  transition: color 0.15s;
}
.companion-ctx-action__btn--dismiss:hover { color: #6a6a6a; }

/* Persistent label (non-clickable, e.g. LIX indicator) */
.companion-ctx-action__label {
  font-size: 11px;
  padding: 4px 12px;
  border-radius: 12px;
  font-weight: 600;
  color: #8a7a6a;
  background: rgba(200, 190, 175, 0.15);
  letter-spacing: 0.01em;
}
.companion-ctx-action--persistent {
  background: rgba(250, 248, 246, 0.7);
  border-color: rgba(220, 215, 205, 0.25);
}
.companion-ctx-action--persistent .companion-ctx-action__text {
  margin-bottom: 6px;
}

/* ── Suggestion card — soft, neutral ───────────────────── */
.companion-suggestion {
  padding: 12px 14px;
  border-radius: 14px;
  background: rgba(250, 248, 246, 0.5);
  border: 1px solid rgba(230, 220, 210, 0.2);
  margin-bottom: 8px;
  cursor: default;
  transition: background 0.25s ease, transform 0.25s ease;
  position: relative;
}
.companion-suggestion:hover {
  background: rgba(248, 246, 242, 0.8);
  transform: translateY(-1px);
}
.companion-suggestion--milestone {
  background: rgba(250, 245, 238, 0.6);
  border-color: rgba(220, 200, 180, 0.3);
}
.companion-suggestion--action {
  border-color: rgba(160, 200, 230, 0.3);
}
.companion-suggestion__icon {
  display: inline-flex;
  vertical-align: -3px;
  color: #c8a070;
  margin-right: 5px;
  flex-shrink: 0;
  opacity: 0.7;
}
.companion-suggestion--milestone .companion-suggestion__icon { color: #e0a060; opacity: 0.8; }
.companion-suggestion--action .companion-suggestion__icon { color: #90b8d8; }
.companion-suggestion--discovery .companion-suggestion__icon { color: #b8a080; }
.companion-suggestion--tip {
  background: #ffffff;
  border-color: rgba(200, 200, 210, 0.25);
}
.companion-suggestion--tip .companion-suggestion__icon { color: #8a8a9a; }
.companion-suggestion__text {
  font-size: 12.5px;
  color: #6a5a4a;
  line-height: 1.6;
  margin-bottom: 10px;
  letter-spacing: 0.005em;
}
.companion-suggestion__actions {
  display: flex;
  gap: 8px;
  align-items: center;
}
.companion-suggestion__btn {
  font-size: 11.5px;
  padding: 5px 14px;
  border-radius: 20px;
  border: none;
  cursor: pointer;
  font-weight: 500;
  transition: background 0.2s, transform 0.15s, color 0.2s;
}
.companion-suggestion__btn:active { transform: scale(0.96); }
.companion-suggestion__btn--primary {
  background: linear-gradient(135deg, #fdd9b5 0%, #ffecd2 100%);
  color: #6a4a2a;
  font-weight: 600;
  box-shadow: 0 1px 4px rgba(200, 150, 80, 0.10);
}
.companion-suggestion__btn--primary:hover {
  background: linear-gradient(135deg, #fcc8a0 0%, #fde0c4 100%);
  box-shadow: 0 2px 8px rgba(200, 150, 80, 0.15);
}
.companion-suggestion__btn--dismiss {
  background: transparent;
  color: #c0b0a0;
  font-weight: 400;
}
.companion-suggestion__btn--dismiss:hover {
  background: rgba(200, 180, 160, 0.08);
  color: #8a7a6a;
}

/* ── Panel footer — minimal, integrated ──────────────── */
.companion-footer {
  padding: 4px 14px 6px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-shrink: 0;
}
.companion-footer__toggle {
  font-size: 10.5px;
  color: #c8b8a8;
  background: none;
  border: none;
  cursor: pointer;
  padding: 2px 0;
  letter-spacing: 0.02em;
  transition: color 0.2s;
}
.companion-footer__toggle:hover {
  color: #a09080;
}
/* ── Inline compose banner (Tier A urgency) ──────────── */
.companion-compose-banner {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 7px 12px;
  margin: 0 0 4px;
  border-radius: 8px;
  background: rgba(232, 93, 58, 0.06);
  border-left: 3px solid #e85d3a;
  font-size: 12.5px;
  color: #6a4a3a;
  line-height: 1.5;
  animation: banner-slide 0.2s ease-out;
}
.companion-compose-banner--warning {
  background: rgba(245, 158, 11, 0.06);
  border-left-color: #f59e0b;
  color: #6a5a2a;
}
.companion-compose-banner__text { flex: 1; }
.companion-compose-banner__action {
  font-size: 11.5px;
  font-weight: 600;
  color: #e85d3a;
  background: none;
  border: none;
  cursor: pointer;
  padding: 2px 8px;
  border-radius: 4px;
  white-space: nowrap;
  transition: background 0.15s;
}
.companion-compose-banner__action:hover { background: rgba(232, 93, 58, 0.08); }
.companion-compose-banner__dismiss {
  color: #b8a898;
  background: none;
  border: none;
  cursor: pointer;
  padding: 2px;
  line-height: 1;
  font-size: 16px;
  opacity: 0.6;
  transition: opacity 0.15s;
}
.companion-compose-banner__dismiss:hover { opacity: 1; }
@keyframes banner-slide {
  from { opacity: 0; transform: translateY(-4px); }
  to   { opacity: 1; transform: translateY(0); }
}
[data-theme=dark] .companion-compose-banner {
  background: rgba(232, 93, 58, 0.08);
  color: #e8c8b8;
}
[data-theme=dark] .companion-compose-banner--warning {
  background: rgba(245, 158, 11, 0.08);
  color: #e8d8a8;
}
[data-theme=dark] .companion-compose-banner__action { color: #f0a080; }


/* ── Loading state for AI review ────────────────────────── */
.companion-ctx-action[data-ctx-id="ctx-review-loading"],
.companion-ctx-action[data-ctx-id="ctx-review-rewriting"] {
  background: linear-gradient(110deg, #ffffff 30%, #f5ede5 50%, #ffffff 70%);
  background-size: 200% 100%;
  animation: ctx-loading-shimmer 1.8s ease-in-out infinite;
}
.companion-ctx-action[data-ctx-id="ctx-review-loading"] .companion-ctx-action__btn,
.companion-ctx-action[data-ctx-id="ctx-review-rewriting"] .companion-ctx-action__btn {
  opacity: 0.5;
  pointer-events: none;
  cursor: default;
}
@keyframes ctx-loading-shimmer {
  0%   { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}
/* ── Tone/language warning accents ─────────────────────── */
.companion-ctx-action[data-ctx-id="ctx-review-tone"],
.companion-ctx-action[data-ctx-id="ctx-review-language"] {
  border-left: none;
  padding-left: 17px;
  position: relative;
}
.companion-ctx-action[data-ctx-id="ctx-review-tone"]::before,
.companion-ctx-action[data-ctx-id="ctx-review-language"]::before {
  content: '';
  position: absolute;
  left: 0;
  top: 8px;
  bottom: 8px;
  width: 3px;
  border-radius: 2px;
}
.companion-ctx-action[data-ctx-id="ctx-review-tone"]::before {
  background: #e85d3a;
}
.companion-ctx-action[data-ctx-id="ctx-review-language"]::before {
  background: #f59e0b;
}

/* ── Dark mode ─────────────────────────────────────────── */
[data-theme="dark"] .companion-blob {
  filter: drop-shadow(0 2px 8px rgba(0,0,0,0.3))
          drop-shadow(0 8px 24px rgba(0,0,0,0.2));
}
[data-theme="dark"] .companion-blob--has-suggestion .companion-blob__stop:nth-child(1) { stop-color: #4a5a8a; }
[data-theme="dark"] .companion-blob--has-suggestion .companion-blob__stop:nth-child(2) { stop-color: #3a4a7a; }
[data-theme="dark"] .companion-blob--has-suggestion .companion-blob__stop:nth-child(3) { stop-color: #2a3a6a; }
[data-theme="dark"] .companion-blob--has-suggestion .companion-blob__stop:nth-child(4) { stop-color: #1e2e5a; }
[data-theme="dark"] .companion-blob--has-suggestion {
  filter: drop-shadow(0 2px 8px rgba(80,100,180,0.3)) drop-shadow(0 8px 24px rgba(80,100,180,0.2));
}
[data-theme="dark"] .companion-panel {
  background: var(--color-card);
  border-color: var(--color-border);
  box-shadow: 0 4px 24px rgba(0, 0, 0, 0.4),
              0 1px 3px rgba(0, 0, 0, 0.2);
}
.companion-header__close {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  border: none;
  background: rgba(0,0,0,0.04);
  color: #a09080;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  transition: background 0.15s, color 0.15s;
  flex-shrink: 0;
}
.companion-header__close:hover {
  background: rgba(0,0,0,0.08);
  color: #6a5a4a;
}
.companion-header__close svg {
  width: 14px;
  height: 14px;
  stroke: currentColor;
  stroke-width: 2;
  fill: none;
}
[data-theme="dark"] .companion-header__close { background: rgba(255,255,255,0.06); color: #8a8098; }
[data-theme="dark"] .companion-header__close:hover { background: rgba(255,255,255,0.12); color: #b0a8b8; }
[data-theme="dark"] .companion-suggestion { background: rgba(60, 55, 70, 0.5); border-color: rgba(80, 70, 90, 0.25); }
[data-theme="dark"] .companion-suggestion:hover { background: rgba(70, 60, 50, 0.5); }
[data-theme="dark"] .companion-suggestion--milestone { background: rgba(70, 55, 40, 0.4); border-color: rgba(160, 120, 80, 0.25); }
[data-theme="dark"] .companion-suggestion--action { border-color: rgba(100, 150, 190, 0.25); }
[data-theme="dark"] .companion-suggestion--tip { background: rgba(50, 48, 60, 0.6); border-color: rgba(80, 70, 90, 0.25); }
[data-theme="dark"] .companion-suggestion__icon { color: #d4a878; }
[data-theme="dark"] .companion-suggestion--milestone .companion-suggestion__icon { color: #e8b870; }
[data-theme="dark"] .companion-suggestion--action .companion-suggestion__icon { color: #88c0e8; }
[data-theme="dark"] .companion-suggestion--discovery .companion-suggestion__icon { color: #c8a888; }
[data-theme="dark"] .companion-suggestion--tip .companion-suggestion__icon { color: #9898a8; }
[data-theme="dark"] .companion-ctx-action { background: rgba(40, 38, 44, 0.85); border-color: rgba(80, 70, 90, 0.25); }
[data-theme="dark"] .companion-ctx-action__text { color: #c8c0d0; }
[data-theme="dark"] .companion-ctx-action__btn {
  background: linear-gradient(135deg, #8a6a40 0%, #7a5a30 100%);
  color: #ffecd2;
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.15);
}
[data-theme="dark"] .companion-ctx-action__btn--dismiss { color: #706878; }
[data-theme="dark"] .companion-ctx-action__btn--dismiss:hover { color: #a098a8; }
[data-theme="dark"] .companion-ctx-action__label { color: #a098a8; background: rgba(80, 70, 90, 0.25); }
[data-theme="dark"] .companion-ctx-action--persistent { background: rgba(40, 38, 50, 0.5); border-color: rgba(80, 70, 90, 0.2); }
[data-theme="dark"] .companion-suggestion__text { color: #c8c0d0; }
[data-theme="dark"] .companion-suggestion__btn--primary {
  background: linear-gradient(135deg, #8a6a40 0%, #6a4a28 100%);
  color: #ffecd2;
}
[data-theme="dark"] .companion-footer__toggle { color: #6a6078; }
[data-theme="dark"] .companion-footer__toggle:hover { color: #908898; }
[data-theme="dark"] .companion-empty { color: #6a6078; }
[data-theme="dark"] .companion-ctx-action[data-ctx-id="ctx-review-tone"]::before { background: #f0a080; }
[data-theme="dark"] .companion-ctx-action[data-ctx-id="ctx-review-language"]::before { background: #e0b040; }
[data-theme="dark"] .companion-ctx-action[data-ctx-id="ctx-review-loading"],
[data-theme="dark"] .companion-ctx-action[data-ctx-id="ctx-review-rewriting"] {
  background: linear-gradient(110deg, rgba(40,38,44,0.85) 30%, rgba(55,50,60,0.85) 50%, rgba(40,38,44,0.85) 70%);
  background-size: 200% 100%;
}

/* ── Sidebar-embedded mode (skrivebord) ─────────────────── */
.companion-sidebar-host {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 0 8px 8px;
  position: relative;
}
.companion-blob--sidebar {
  position: relative;
  bottom: auto;
  right: auto;
  width: 52px;
  height: 52px;
  z-index: 1;
  filter: drop-shadow(0 2px 6px rgba(180,130,80,0.14));
}
.companion-blob--sidebar:hover {
  transform: scale(1.08);
}
.companion-panel--sidebar {
  position: absolute;
  bottom: 62px;
  left: 50%;
  right: auto;
  transform-origin: bottom center;
  width: 280px;
  max-height: 360px;
  z-index: 200;
}
.companion-panel--sidebar.companion-panel--open {
  transform: translateX(-50%);
  animation: panel-appear-sidebar 0.3s cubic-bezier(0.25, 1, 0.5, 1);
}
@keyframes panel-appear-sidebar {
  from { opacity: 0; transform: translateX(-50%) translateY(6px) scale(0.96); }
  to   { opacity: 1; transform: translateX(-50%) translateY(0) scale(1); }
}
/* Collapsed sidebar: smaller blob */
.sidebar.collapsed .companion-sidebar-host {
  padding: 0 4px 6px;
}
.sidebar.collapsed .companion-blob--sidebar {
  width: 40px;
  height: 40px;
}
.sidebar.collapsed .companion-panel--sidebar {
  width: 260px;
  left: 44px;
  bottom: 0;
  transform-origin: bottom left;
}
.sidebar.collapsed .companion-panel--sidebar.companion-panel--open {
  transform: none;
  animation: panel-appear 0.3s cubic-bezier(0.25, 1, 0.5, 1);
}
/* Tablet: sidebar auto-collapses — shrink blob to fit */
@media (max-width: 1279px) {
  .companion-sidebar-host { padding: 0 4px 6px; }
  .companion-blob--sidebar { width: 40px; height: 40px; }
  .companion-panel--sidebar {
    width: 260px;
    left: 44px;
    bottom: 0;
    transform-origin: bottom left;
  }
  .companion-panel--sidebar.companion-panel--open {
    transform: none;
  }
}
/* Mobile: hide sidebar companion (sidebar itself is hidden) */
@media (max-width: 767px) {
  .companion-sidebar-host { display: none; }
}

/* ── Mobile ────────────────────────────────────────────── */
@media (max-width: 767px) {
  .companion-blob {
    bottom: 80px;
    right: 14px;
    width: 56px;
    height: 56px;
  }
  .companion-panel {
    bottom: 148px;
    right: 10px;
    width: calc(100vw - 28px);
    max-height: 320px;
    border-radius: 18px;
  }
}

/* ── Reduced motion (EU Accessibility Act 2025) ────────── */
@media (prefers-reduced-motion: reduce) {
  .companion-blob__body { animation: none; }
  .companion-blob__svg { animation: none; }
  .companion-blob__glow { animation: none; }
  .companion-blob__sparkle { animation: none; }
  .companion-blob--jiggle .companion-blob__body { animation: none; }
  .companion-blob--has-suggestion { animation: none; }
  .companion-blob--nudge { animation: none; }
  .companion-panel--open { animation: none; }
  .companion-panel--closing { animation: none; }
  .companion-ctx-action[data-ctx-id="ctx-review-loading"],
  .companion-ctx-action[data-ctx-id="ctx-review-rewriting"] { animation: none; }
  .companion-blob,
  .companion-blob__stop,
  .companion-blob__pupil,
  .companion-blob__brow {
    transition: none;
  }
}

/* ── Print ─────────────────────────────────────────────── */
@media print {
  .companion-blob, .companion-panel { display: none !important; }
}
