/* Divinci homepage free-chat widget — floating bubble + panel.
   Uses the site's brand tokens (variables.css) so it matches divinci.ai. */

.dvc-root { position: fixed; right: 20px; bottom: 20px; z-index: 9999;
  font-family: "Source Sans 3", system-ui, -apple-system, sans-serif; }

.dvc-bubble {
  width: 56px; height: 56px; border-radius: 50%; border: none; cursor: pointer;
  font-size: 24px; line-height: 1; color: #fff;
  background: var(--color-neutral-inverse, #2d5a4f);
  box-shadow: 0 6px 20px rgba(30, 58, 43, 0.35);
  transition: transform .15s ease, background .15s ease;
}
.dvc-bubble:hover { transform: translateY(-2px); background: var(--color-accent-tertiary, #3d6b4f); }
.dvc-bubble-open { background: var(--color-accent-secondary, #8b7659); }

.dvc-panel {
  position: absolute; right: 0; bottom: 72px; width: 360px; max-width: calc(100vw - 40px);
  height: 480px; max-height: calc(100vh - 120px); display: flex; flex-direction: column;
  background: var(--color-bg-primary, #f8f4f0);
  border: 1px solid var(--color-bg-accent, #e8ddc7); border-radius: 14px; overflow: hidden;
  box-shadow: 0 12px 40px rgba(30, 58, 43, 0.28);
}
.dvc-hidden { display: none; }

.dvc-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 16px; background: var(--color-neutral-inverse, #2d5a4f); color: #fff;
  font-family: "Fraunces", Georgia, serif; font-weight: 600; font-size: 16px;
}
.dvc-close { background: none; border: none; color: #fff; font-size: 22px; cursor: pointer; line-height: 1; padding: 0 4px; }

.dvc-body { flex: 1; display: flex; flex-direction: column; min-height: 0; }
.dvc-pad { padding: 18px 16px; display: flex; flex-direction: column; gap: 12px; }
.dvc-center { align-items: center; text-align: center; justify-content: center; flex: 1; }

.dvc-lead { margin: 0; color: var(--color-text-primary, #2d3c34); font-size: 14px; line-height: 1.45; }
.dvc-muted { margin: 0; color: var(--color-text-secondary, #7e8d95); font-size: 12px; }
.dvc-err { margin: 0; color: #b00020; font-size: 13px; min-height: 16px; }

.dvc-input {
  width: 100%; box-sizing: border-box; padding: 10px 12px; font-size: 14px;
  border: 1px solid var(--color-bg-accent, #e8ddc7); border-radius: 8px;
  background: #fff; color: var(--color-text-primary, #2d3c34);
}
.dvc-input:focus { outline: none; border-color: var(--color-accent-primary, #b8a080); }
.dvc-code { letter-spacing: 6px; font-size: 18px; text-align: center; }

.dvc-btn {
  display: inline-block; text-align: center; text-decoration: none; padding: 10px 14px;
  border: none; border-radius: 8px; cursor: pointer; font-size: 14px; font-weight: 600;
  color: #fff; background: var(--color-neutral-inverse, #2d5a4f);
}
.dvc-btn:hover { background: var(--color-accent-tertiary, #3d6b4f); }
.dvc-btn:disabled { opacity: .6; cursor: default; }
.dvc-cta { background: var(--color-accent-primary, #b8a080); }
.dvc-cta:hover { background: var(--color-accent-primary-hover, #a6946b); }
.dvc-link { background: none; border: none; color: var(--color-text-secondary, #7e8d95); font-size: 12px; cursor: pointer; text-decoration: underline; padding: 0; }
.dvc-turnstile { min-height: 65px; }

.dvc-chat { display: flex; flex-direction: column; flex: 1; min-height: 0; }
.dvc-messages { flex: 1; overflow-y: auto; padding: 14px; display: flex; flex-direction: column; gap: 10px; }
.dvc-msg { max-width: 85%; padding: 9px 12px; border-radius: 12px; font-size: 14px; line-height: 1.4; white-space: pre-wrap; word-wrap: break-word; }
.dvc-msg-user { align-self: flex-end; background: var(--color-neutral-inverse, #2d5a4f); color: #fff; border-bottom-right-radius: 4px; }
.dvc-msg-assistant { align-self: flex-start; background: var(--color-bg-accent, #e8ddc7); color: var(--color-text-primary, #2d3c34); border-bottom-left-radius: 4px; }
.dvc-meta { padding: 0 14px; }
.dvc-inputrow { display: flex; gap: 8px; padding: 10px 12px; border-top: 1px solid var(--color-bg-accent, #e8ddc7); }
.dvc-send { flex: 0 0 auto; width: 40px; border: none; border-radius: 8px; cursor: pointer; font-size: 18px; color: #fff; background: var(--color-neutral-inverse, #2d5a4f); }
.dvc-send:hover { background: var(--color-accent-tertiary, #3d6b4f); }

@media (max-width: 480px) {
  .dvc-panel { width: calc(100vw - 24px); right: -4px; height: 70vh; }
}
