#assistantToggle {
  position: fixed;
  right: var(--space-4);
  bottom: calc(var(--space-6) + env(safe-area-inset-bottom));
  z-index: var(--z-dropdown);
  border: none;
  border-radius: var(--radius-full);
  min-height: 48px;
  padding: 0 var(--space-4);
  background: var(--color-accent);
  color: var(--color-text);
  cursor: pointer;
  font-weight: 600;
  font-size: var(--text-sm);
  box-shadow: var(--shadow-md);
  transition:
    background var(--transition-fast),
    box-shadow var(--transition-fast),
    transform var(--transition-fast);
}

@media (hover: hover) {
  #assistantToggle:hover {
    box-shadow: var(--shadow-accent);
    transform: translateY(-1px);
  }
}

#assistantToggle:focus-visible {
  outline: 2px solid var(--color-text);
  outline-offset: 3px;
}

#assistantPanel {
  position: fixed;
  right: var(--space-4);
  bottom: calc(72px + var(--space-6) + env(safe-area-inset-bottom));
  width: min(360px, calc(100vw - var(--space-8)));
  max-height: min(70vh, 520px);
  display: none;
  flex-direction: column;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  background: var(--color-surface);
  box-shadow: var(--shadow-lg);
  z-index: var(--z-dropdown);
  overflow: hidden;
}

#assistantPanel.open {
  display: flex;
}

#assistantHeader {
  padding: var(--space-3) var(--space-4);
  border-bottom: 1px solid var(--color-border);
  font-size: var(--text-sm);
  font-weight: 600;
}

#assistantHints {
  display: grid;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-4);
  border-bottom: 1px solid var(--color-border);
}

#assistantHints button {
  text-align: left;
  border: 1px solid var(--color-border);
  background: var(--color-surface-alt);
  color: var(--color-text-muted);
  border-radius: var(--radius-md);
  min-height: 44px;
  padding: var(--space-2) var(--space-3);
  cursor: pointer;
  font-size: var(--text-xs);
  transition:
    background var(--transition-fast),
    border-color var(--transition-fast),
    color var(--transition-fast);
}

@media (hover: hover) {
  #assistantHints button:hover {
    background: color-mix(in srgb, var(--color-accent) 12%, var(--color-surface-alt));
    border-color: color-mix(in srgb, var(--color-accent) 35%, transparent);
    color: var(--color-text);
  }
}

#assistantHints button:focus-visible {
  outline: 2px solid var(--color-accent);
  outline-offset: 2px;
}

#assistantMessages {
  overflow: auto;
  padding: var(--space-4);
  display: grid;
  gap: var(--space-2);
  font-size: var(--text-sm);
  flex: 1;
  min-height: 0;
}

.assistantMsg {
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-md);
  white-space: pre-wrap;
  word-break: break-word;
}

.assistantMsg.user {
  background: color-mix(in srgb, var(--color-accent) 25%, var(--color-surface));
  color: var(--color-text);
}

.assistantMsg.bot {
  background: var(--color-surface-alt);
  color: var(--color-text-muted);
}

.assistantMsg--loading {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  color: var(--color-text-muted);
}

.assistant-spinner {
  flex-shrink: 0;
  width: 20px;
  height: 20px;
  border: 2px solid var(--color-border);
  border-top-color: var(--color-accent);
  border-radius: 50%;
  animation: assistantSpin 0.75s linear infinite;
}

.assistant-loading-text {
  font-size: var(--text-sm);
}

@keyframes assistantSpin {
  to {
    transform: rotate(360deg);
  }
}

#assistantSend:disabled,
#assistantInput:disabled {
  opacity: 0.65;
  cursor: not-allowed;
}

.assistantMsg--markdown {
  white-space: normal;
}

.assistantMsg--markdown p {
  margin: 0 0 var(--space-2);
  color: inherit;
}

.assistantMsg--markdown p:last-child {
  margin-bottom: 0;
}

.assistantMsg--markdown h3,
.assistantMsg--markdown h4 {
  margin: 0 0 var(--space-2);
  font-family: var(--font-display);
  font-size: var(--text-base);
  font-weight: 600;
  color: var(--color-text);
  line-height: 1.3;
}

.assistantMsg--markdown h4 {
  font-size: var(--text-sm);
}

.assistantMsg--markdown ul,
.assistantMsg--markdown ol {
  margin: 0 0 var(--space-2);
  padding-left: var(--space-5);
}

.assistantMsg--markdown li {
  margin-bottom: var(--space-1);
}

.assistantMsg--markdown li:last-child {
  margin-bottom: 0;
}

.assistantMsg--markdown code {
  font-family: var(--font-mono);
  font-size: 0.9em;
  padding: 0.1em 0.35em;
  border-radius: var(--radius-sm);
  background: color-mix(in srgb, var(--color-bg) 50%, transparent);
  color: var(--color-text);
}

.assistantMsg--markdown pre {
  margin: 0 0 var(--space-2);
  padding: var(--space-3);
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--color-bg) 55%, transparent);
  overflow-x: auto;
}

.assistantMsg--markdown pre code {
  padding: 0;
  background: transparent;
  white-space: pre-wrap;
  word-break: break-word;
}

.assistantMsg--markdown blockquote {
  margin: 0 0 var(--space-2);
  padding-left: var(--space-3);
  border-left: 3px solid color-mix(in srgb, var(--color-accent) 50%, transparent);
  color: var(--color-text-muted);
}

.assistantMsg--markdown a {
  color: var(--color-accent);
  text-decoration: underline;
  text-underline-offset: 2px;
}

.assistantMsg--markdown strong {
  color: var(--color-text);
  font-weight: 600;
}

.assistantMsg--markdown em {
  font-style: italic;
}

#assistantForm {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-4);
  border-top: 1px solid var(--color-border);
}

#assistantInput {
  border-radius: var(--radius-md);
  border: 1px solid var(--color-border);
  background: var(--color-surface-alt);
  color: var(--color-text);
  min-height: 44px;
  padding: 0 var(--space-3);
  font-size: var(--text-sm);
  width: 100%;
}

#assistantInput:focus {
  outline: none;
  border-color: var(--color-accent);
  box-shadow: 0 0 0 3px var(--color-accent-glow);
}

#assistantSend {
  border: none;
  border-radius: var(--radius-md);
  background: var(--color-accent);
  color: var(--color-text);
  min-height: 44px;
  min-width: 44px;
  padding: 0 var(--space-4);
  cursor: pointer;
  font-weight: 600;
  font-size: var(--text-sm);
  transition:
    background var(--transition-fast),
    box-shadow var(--transition-fast);
}

@media (hover: hover) {
  #assistantSend:hover {
    box-shadow: 0 0 20px var(--color-accent-glow);
  }
}

#assistantSend:focus-visible {
  outline: 2px solid var(--color-text);
  outline-offset: 2px;
}

@media (min-width: 1024px) {
  #assistantToggle {
    bottom: calc(var(--space-4) + env(safe-area-inset-bottom));
  }

  #assistantPanel {
    bottom: calc(64px + var(--space-4) + env(safe-area-inset-bottom));
  }
}
