/**
 * Polaris Career AI widget styles — ADDITIONS ONLY.
 *
 * Does NOT style .careerai-input, .careerai-suggestions, or .careerai-input__*
 * — those live in the theme's existing stylesheet and stay untouched.
 *
 * Every value derives from the existing design-system tokens (--brand-primary,
 * --color-surface, --text-muted, etc.) so widget surfaces inherit the
 * surrounding theme automatically. Mirrors the visual language of
 * packages/design-system/project/ui_kits/career-ai/Scenes.jsx :: AnswerScene.
 */

/* Hide chips after first submit. Theme owns the resting visual; we just
   collapse them when the conversation begins. */
.careerai-suggestions--hidden {
  display: none !important;
}

/* ── Conversation container (JS-injected after .careerai-suggestions) ── */
.careerai-conversation {
  display: flex;
  flex-direction: column;
  gap: 24px;
  margin: 24px auto 0;
  max-width: 760px;
  padding: 0 8px;
  /* The hero parent (.careerai-hero__main) center-aligns text. Reset for
     the conversation so prose, lists, and headings read left-to-right. */
  text-align: left;
}

/* ── Message bubbles ────────────────────────────────────────────────── */
.careerai-msg {
  font-family: var(
    --font-body,
    system-ui,
    -apple-system,
    "Segoe UI",
    Roboto,
    sans-serif
  );
  font-size: 16px;
  line-height: 1.6;
  color: var(--text-primary, #181817);
  word-wrap: break-word;
  animation: careerai-msg-in 200ms ease-out;
}

.careerai-msg--user {
  align-self: flex-end;
  max-width: 78%;
  padding: 12px 16px;
  border-radius: 12px 12px 4px 12px;
  background: var(--color-surface-soft, var(--neutral-50, #f7f5f0));
  font-size: 15px;
}

.careerai-msg--assistant {
  align-self: stretch;
  background: transparent;
}

/* ── Markdown body styles ───────────────────────────────────────────── */
.careerai-msg__body {
  white-space: normal;
}
.careerai-msg__body > *:first-child {
  margin-top: 0;
}
.careerai-msg__body > *:last-child {
  margin-bottom: 0;
}

.careerai-msg__body p {
  margin: 0 0 14px;
  line-height: 1.6;
}

.careerai-md-h4 {
  font-family: var(--font-body, inherit);
  font-size: 16px;
  font-weight: 600;
  margin: 18px 0 8px;
  color: var(--text-primary, #181817);
}

.careerai-md-ul,
.careerai-md-ol {
  margin: 0 0 16px;
  padding-left: 22px;
  line-height: 1.65;
}
.careerai-md-ul li,
.careerai-md-ol li {
  margin-bottom: 4px;
}

.careerai-msg__body strong {
  font-weight: 600;
  color: var(--text-primary, #181817);
}

/* ── Inline links (markdown [text](url) + auto-linkified bare URLs) ─── */
.careerai-md-link {
  color: var(--brand-primary, #1f8a4c);
  text-decoration: underline;
  text-underline-offset: 2px;
  text-decoration-thickness: 1px;
  transition: color 120ms ease;
  word-break: break-word; /* Long URLs shouldn't break the layout */
}
.careerai-md-link:hover,
.careerai-md-link:focus-visible {
  color: var(--brand-primary-dark, var(--brand-primary, #166c3a));
  text-decoration-thickness: 2px;
  outline: none;
}

/* ── Inline citation chip ───────────────────────────────────────────── */
.careerai-cite {
  display: inline-flex;
  align-items: center;
  background: var(
    --brand-primary-ghost,
    color-mix(in srgb, var(--brand-primary, #1f8a4c) 12%, transparent)
  );
  color: var(--brand-primary-dark, var(--brand-primary, #1f8a4c));
  border-radius: 6px;
  padding: 0 5px;
  font-size: 11px;
  font-weight: 700;
  text-decoration: none;
  vertical-align: super;
  line-height: 1.4;
  margin: 0 1px;
  cursor: pointer;
  transition: background 120ms ease;
}
.careerai-cite:hover,
.careerai-cite:focus-visible {
  background: color-mix(
    in srgb,
    var(--brand-primary, #1f8a4c) 24%,
    transparent
  );
  text-decoration: none;
  outline: none;
}

/* ── Confidence badge ───────────────────────────────────────────────── */
.careerai-confidence-slot:empty {
  display: none;
}
.careerai-confidence {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  border-radius: 999px;
  border: 1px solid;
  font-size: 12px;
  font-weight: 600;
  margin-bottom: 12px;
}
.careerai-confidence--medium {
  background: var(--brand-highlight-subtle, #fff8e6);
  color: #a07300;
  border-color: rgba(160, 115, 0, 0.2);
}
.careerai-confidence--low {
  background: var(--brand-accent-subtle, #fff0e6);
  color: #d44e01;
  border-color: rgba(212, 78, 1, 0.2);
}
.careerai-confidence__icon {
  width: 14px;
  height: 14px;
  display: inline-grid;
  place-items: center;
  border-radius: 50%;
  background: currentColor;
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  font-style: italic;
}

/* ── Streaming cursor ───────────────────────────────────────────────── */
.careerai-cursor {
  display: inline-block;
  width: 2px;
  height: 1.1em;
  background: var(--brand-primary, #1f8a4c);
  margin-left: 2px;
  vertical-align: text-bottom;
  animation: careerai-blink 1s linear infinite;
}

/* ── Action row (copy / helpful / not helpful) ──────────────────────── */
.careerai-actions {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-top: 16px;
  color: var(--text-muted, #9e9997);
  font-size: 13px;
}
.careerai-actions__btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 10px;
  background: transparent;
  color: var(--text-muted, #9e9997);
  border: 1px solid transparent;
  border-radius: 8px;
  font-family: inherit;
  font-size: 13px;
  cursor: pointer;
  transition: all 150ms ease;
}
.careerai-actions__btn:hover {
  background: var(--color-surface-soft, var(--neutral-50, #f7f5f0));
  color: var(--text-primary, #181817);
  border-color: var(--color-border, #e3ded6);
}
.careerai-actions__btn:focus-visible {
  outline: 2px solid var(--brand-primary, #1f8a4c);
  outline-offset: 2px;
}
.careerai-actions__btn--active {
  color: var(--brand-primary, #1f8a4c);
  background: color-mix(in srgb, var(--brand-primary, #1f8a4c) 8%, transparent);
}
.careerai-actions__flash {
  margin-left: 8px;
  font-size: 12px;
  color: var(--brand-primary, #1f8a4c);
  animation: careerai-msg-in 150ms ease-out;
}

/* ── References (Sources block) ─────────────────────────────────────── */
.careerai-references {
  margin-top: 20px;
  padding-top: 16px;
  border-top: 1px solid var(--color-border, #e3ded6);
}
.careerai-references__header {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-muted, #9e9997);
  margin-bottom: 10px;
}
.careerai-references__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.careerai-references__item {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  padding: 6px 8px;
  border-radius: 8px;
  transition: background 200ms ease;
}
.careerai-references__item--flash {
  background: color-mix(
    in srgb,
    var(--brand-primary, #1f8a4c) 10%,
    transparent
  );
}
.careerai-references__num {
  flex-shrink: 0;
  width: 22px;
  height: 22px;
  border-radius: 6px;
  background: var(
    --brand-primary-ghost,
    color-mix(in srgb, var(--brand-primary, #1f8a4c) 12%, transparent)
  );
  color: var(--brand-primary-dark, var(--brand-primary, #1f8a4c));
  display: inline-grid;
  place-items: center;
  font-size: 11px;
  font-weight: 700;
}
.careerai-references__body {
  flex: 1;
  min-width: 0;
}
.careerai-references__title {
  font-size: 14px;
  font-weight: 500;
  color: var(--text-primary, #181817);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.careerai-references__title:hover {
  color: var(--brand-primary, #1f8a4c);
  text-decoration: none;
}
.careerai-references__ext {
  color: var(--text-muted, #9e9997);
  font-size: 11px;
}
.careerai-references__meta {
  font-size: 12px;
  color: var(--text-muted, #9e9997);
  margin-top: 2px;
}
.careerai-references__tier {
  font-weight: 600;
}
.careerai-references__tier--t1 {
  color: var(--brand-primary, #1f8a4c);
}
.careerai-references__tier--t2 {
  color: #a07300;
}
.careerai-references__tier--t3 {
  color: var(--text-muted, #9e9997);
}

.careerai-references__more {
  margin-top: 10px;
  background: transparent;
  border: none;
  color: var(--brand-primary, #1f8a4c);
  font-family: inherit;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  padding: 0;
}
.careerai-references__more:hover {
  text-decoration: underline;
}

/* ── Suggested follow-ups (perplexity-style stack) ──────────────────── */
.careerai-followups {
  margin-top: 20px;
  padding-top: 16px;
  border-top: 1px dashed var(--color-border, #e3ded6);
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.careerai-followups__header {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-muted, #9e9997);
  margin-bottom: 6px;
}
.careerai-followups__btn {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  padding: 10px 14px;
  background: var(--color-surface-soft, var(--neutral-50, #f7f5f0));
  border: 1px solid var(--color-border, #e3ded6);
  border-radius: 10px;
  font-family: inherit;
  font-size: 14px;
  font-weight: 500;
  text-align: left;
  color: var(--text-primary, #181817);
  cursor: pointer;
  transition: all 150ms ease;
}
.careerai-followups__btn:hover {
  border-color: var(--brand-primary, #1f8a4c);
  color: var(--brand-primary, #1f8a4c);
  transform: translateX(2px);
}
.careerai-followups__btn:focus-visible {
  outline: 2px solid var(--brand-primary, #1f8a4c);
  outline-offset: 2px;
}
.careerai-followups__arrow {
  color: var(--text-muted, #9e9997);
  flex-shrink: 0;
  font-size: 14px;
}
.careerai-followups__btn:hover .careerai-followups__arrow {
  color: var(--brand-primary, #1f8a4c);
}

/* ── CTA banner (Polaris promotion line, inside answer) ─────────────── */
.careerai-cta {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-top: 20px;
  padding: 14px 18px;
  background: linear-gradient(
    135deg,
    var(--brand-primary, #1f8a4c),
    var(--brand-primary-dark, #166c3a)
  );
  color: #fff;
  text-decoration: none;
  border-radius: 12px;
  box-shadow: 0 4px 14px rgba(73, 156, 87, 0.25);
  transition:
    transform 150ms ease,
    box-shadow 150ms ease;
}
.careerai-cta:hover {
  transform: translateY(-1px);
  box-shadow: 0 6px 18px rgba(73, 156, 87, 0.32);
  color: #fff;
  text-decoration: none;
}
.careerai-cta__icon {
  width: 32px;
  height: 32px;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.18);
  display: inline-grid;
  place-items: center;
  flex-shrink: 0;
  font-size: 16px;
}
.careerai-cta__body {
  flex: 1;
  min-width: 0;
}
.careerai-cta__title {
  font-size: 14px;
  font-weight: 600;
  line-height: 1.3;
}
.careerai-cta__sub {
  font-size: 12px;
  opacity: 0.85;
  margin-top: 2px;
}
.careerai-cta__arrow {
  flex-shrink: 0;
  font-size: 18px;
  opacity: 0.9;
}

/* ── Refusal styling ────────────────────────────────────────────────── */
.careerai-msg--refusal {
  background: var(--brand-highlight-subtle, #fff8e6);
  border: 1px solid color-mix(in srgb, #a07300 25%, transparent);
  border-radius: 12px;
  padding: 14px 16px;
}
.careerai-msg--refusal .careerai-msg__body {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  font-size: 15px;
  line-height: 1.55;
}
.careerai-msg__refusal-icon {
  flex-shrink: 0;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: #a07300;
  color: #fff;
  display: inline-grid;
  place-items: center;
  font-size: 12px;
  font-weight: 700;
  font-style: italic;
  margin-top: 1px;
}
.careerai-msg__refusal-body {
  flex: 1;
  min-width: 0;
}

/* ── Error styling ──────────────────────────────────────────────────── */
.careerai-msg--error {
  background: var(--status-error-bg, #fef2f2);
  border: 1px solid
    color-mix(in srgb, var(--status-error, #dc2626) 30%, transparent);
  border-radius: 12px;
  padding: 14px 16px;
}
.careerai-msg--error .careerai-msg__body {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  font-size: 14px;
}
.careerai-msg__error-text {
  color: var(--status-error, #dc2626);
  flex: 1;
}
.careerai-retry {
  flex-shrink: 0;
  background: #fff;
  border: 1px solid var(--color-border-strong, var(--neutral-300, #d6d1ca));
  border-radius: 8px;
  padding: 6px 12px;
  font-family: inherit;
  font-size: 13px;
  font-weight: 600;
  color: var(--text-primary, #181817);
  cursor: pointer;
}
.careerai-retry:hover {
  border-color: var(--brand-primary, #1f8a4c);
  color: var(--brand-primary, #1f8a4c);
}

/* ── Animations ─────────────────────────────────────────────────────── */
@keyframes careerai-blink {
  0%,
  49% {
    opacity: 1;
  }
  50%,
  100% {
    opacity: 0;
  }
}
@keyframes careerai-msg-in {
  from {
    opacity: 0;
    transform: translateY(4px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
@media (prefers-reduced-motion: reduce) {
  .careerai-cursor {
    animation: none;
    opacity: 1;
  }
  .careerai-msg {
    animation: none;
  }
  .careerai-actions__flash {
    animation: none;
  }
  .careerai-followups__btn:hover {
    transform: none;
  }
  .careerai-cta:hover {
    transform: none;
  }
}

/* ── Mobile ─────────────────────────────────────────────────────────── */
@media (max-width: 640px) {
  .careerai-conversation {
    padding: 0 4px;
  }
  .careerai-cta {
    flex-direction: column;
    align-items: flex-start;
  }
  .careerai-actions__btn {
    padding: 8px 10px;
  }
}

/* Streaming-state input lock — purely cursor hint, no visual override. */
.careerai-input[data-state="streaming"] .careerai-input__field {
  cursor: not-allowed;
}

/* ── Docked command-bar mode (after first submit) ───────────────────── */

/* Form fixes to viewport bottom; flow above collapses since position:fixed
   removes the element from normal flow. The hero heading + subhead reflow
   tight against the conversation below them — no awkward gap. */
.careerai-input.careerai-input--docked {
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 80;
  margin: 0;
  max-width: none;
  padding: 12px 16px;
  /* env() lifts above the iPhone home-indicator on iOS Safari. */
  padding-bottom: calc(12px + env(safe-area-inset-bottom, 0px));
  background: var(--color-surface, #ffffff);
  border: none;
  border-top: 1px solid var(--color-border, #e3ded6);
  border-radius: 0;
  box-shadow: 0 -6px 24px rgba(0, 0, 0, 0.06);
  animation: careerai-dock-in 220ms cubic-bezier(0.16, 1, 0.3, 1) both;
}

/* Center the input shell within the full-bleed docked bar so it lines up
   with the conversation column above it. */
.careerai-input.careerai-input--docked .careerai-input__shell {
  max-width: 760px;
  margin: 0 auto;
}

/* scrollIntoView({block:'nearest'}) on a streamed message would otherwise
   land it behind the docked bar. Padding the scroll container's bottom
   pushes the focus point above the docked overlay. */
html.careerai--has-docked-bar {
  scroll-padding-bottom: 120px;
}

@keyframes careerai-dock-in {
  from {
    transform: translateY(100%);
  }
  to {
    transform: translateY(0);
  }
}

@media (prefers-reduced-motion: reduce) {
  .careerai-input--docked {
    animation: none;
  }
}

@media (max-width: 640px) {
  .careerai-input.careerai-input--docked {
    padding: 10px 12px;
    padding-bottom: calc(10px + env(safe-area-inset-bottom, 0px));
  }
}
