/* =========================================================
   CPC PRAXIS THEME — SOFT GLASS / CPC BRAND
   Load LAST
   ========================================================= */

:root {
  --cpc-ink: #003849;
  --cpc-ink-soft: #005569;
  --cpc-green: #a7c900;
  --cpc-green-soft: rgba(167, 201, 0, 0.16);
  --cpc-bg: #f6f7f8;
  --cpc-surface: #ffffff;
  --cpc-border: #e5e7eb;
  --cpc-text: #1d1f21;

  --cpc-shadow-soft: 0 18px 44px rgba(0, 56, 73, 0.14);
  --cpc-shadow-card: 0 10px 28px rgba(0, 56, 73, 0.10);
  --cpc-radius-xl: 28px;
  --cpc-radius-lg: 20px;
  --cpc-radius-md: 14px;
}

/* ---------- PRAXIS shell ---------- */

.dki-praxis-shell {
  position: relative;
  z-index: 1200;

  --praxis-bg: linear-gradient(180deg, #fbfcfd 0%, #f3f6f7 100%);
  --praxis-surface: var(--cpc-surface);
  --praxis-dark: var(--cpc-ink);
  --praxis-border: var(--cpc-border);
  --praxis-accent: var(--cpc-green);
  --praxis-radius: var(--cpc-radius-xl);
}

/* ---------- floating launcher ---------- */

.dki-praxis-sticky-container {
  position: fixed;
  right: 22px;
  bottom: 22px;
  z-index: 1202;
  transition:
    right 0.22s ease,
    bottom 0.22s ease,
    opacity 0.18s ease,
    transform 0.18s ease;
}

.dki-praxis-btn {
  width: 90px !important;
  height: 90px !important;
  min-width: 90px !important;
  min-height: 90px !important;

  display: flex !important;
  align-items: center !important;
  justify-content: center !important;

  border-radius: 30px !important;

  background:
    radial-gradient(circle at 28% 22%, rgba(255,255,255,0.98), rgba(255,255,255,0.82) 48%, rgba(246,247,248,0.94) 100%) !important;

  border: 2px solid rgba(0, 56, 73, 0.22) !important;

  box-shadow:
    0 18px 38px rgba(0, 56, 73, 0.18),
    inset 0 1px 0 rgba(255,255,255,0.88),
    0 0 0 7px rgba(167, 201, 0, 0.08) !important;

  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);

  transition:
    transform 0.16s ease,
    box-shadow 0.16s ease,
    border-color 0.16s ease,
    background 0.16s ease;
}

.dki-praxis-btn:hover,
.dki-praxis-btn:focus {
  transform: translateY(-2px) scale(1.015);

  border-color: rgba(167, 201, 0, 0.82) !important;

  box-shadow:
    0 22px 48px rgba(0, 56, 73, 0.22),
    inset 0 1px 0 rgba(255,255,255,0.94),
    0 0 0 9px rgba(167, 201, 0, 0.14) !important;

  outline: none !important;
}

.dki-praxis-btn svg {
  display: block;
  overflow: visible;
  color: var(--cpc-ink) !important;
  fill: var(--cpc-ink) !important;
  filter: drop-shadow(0 2px 2px rgba(0,56,73,0.10));
}

.dki-praxis-btn:hover svg {
  color: var(--cpc-ink-soft) !important;
  fill: var(--cpc-ink-soft) !important;
}

/* move launcher left when drawer is open */
.dki-praxis-shell.praxis-is-open .dki-praxis-sticky-container {
  right: min(34vw + 18px, 640px);
}

/* ---------- backdrop ---------- */

.dki-praxis-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(0, 56, 73, 0.10);
  z-index: 1198;
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
}

/* ---------- drawer ---------- */

.dki-praxis-drawer {
  position: fixed !important;
  top: 16px !important;
  right: 16px !important;
  bottom: 20px !important;

  width: min(500px, calc(100vw - 32px)) !important;
  min-width: 380px;

  height: auto !important;
  max-height: calc(100vh - 36px) !important;

  display: flex !important;
  flex-direction: column !important;

  background: var(--praxis-bg) !important;

  border: 1px solid rgba(0, 56, 73, 0.12) !important;
  border-radius: var(--praxis-radius) !important;

  box-shadow:
    0 28px 80px rgba(0, 56, 73, 0.24),
    inset 0 1px 0 rgba(255,255,255,0.9) !important;

  z-index: 1201;

  transform: translateX(calc(100% + 42px)) !important;
  opacity: 0;
  pointer-events: none;

  transition:
    transform 0.24s ease,
    opacity 0.18s ease,
    width 0.22s ease !important;

  overflow: hidden !important;
}

.dki-praxis-drawer.is-open {
  transform: translateX(0) !important;
  opacity: 1 !important;
  pointer-events: auto !important;
}

.dki-praxis-drawer.is-expanded {
  width: min(960px, calc(100vw - 32px)) !important;
}

/* ---------- header ---------- */

.dki-praxis-panel-header {
  flex: 0 0 auto !important;

  padding: 16px 18px 14px !important;

  background:
    linear-gradient(135deg, rgba(0,56,73,0.98) 0%, rgba(0,85,105,0.96) 72%, rgba(167,201,0,0.74) 160%) !important;

  color: #ffffff !important;

  border-bottom: 4px solid rgba(167, 201, 0, 0.86) !important;

  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.12),
    0 8px 24px rgba(0,56,73,0.14) !important;
}

.dki-praxis-title {
  font-size: 22px !important;
  font-weight: 850 !important;
  line-height: 1.1 !important;
  color: #ffffff !important;
  letter-spacing: 0.02em;
}

.dki-praxis-panel-header .text-muted {
  color: rgba(255,255,255,0.76) !important;
}

.dki-praxis-header-actions {
  display: flex;
  align-items: center;
  gap: 6px;
}

.dki-praxis-expand,
.dki-praxis-close,
.dki-praxis-panel-header .btn {
  width: 38px !important;
  height: 38px !important;

  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;

  border-radius: 13px !important;

  background: rgba(255,255,255,0.12) !important;
  border: 1px solid rgba(255,255,255,0.22) !important;

  color: #ffffff !important;

  box-shadow: none !important;

  transition:
    background 0.14s ease,
    transform 0.14s ease,
    border-color 0.14s ease;
}

.dki-praxis-expand:hover,
.dki-praxis-close:hover,
.dki-praxis-panel-header .btn:hover {
  background: rgba(167, 201, 0, 0.22) !important;
  border-color: rgba(167, 201, 0, 0.72) !important;
  color: #ffffff !important;
  transform: translateY(-1px);
}

/* ---------- context bar ---------- */

.dki-praxis-workspace-bar {
  flex: 0 0 auto !important;

  padding: 11px 16px !important;

  background:
    linear-gradient(180deg, rgba(255,255,255,0.98), rgba(250,252,252,0.96)) !important;

  border-bottom: 1px solid rgba(0, 56, 73, 0.10) !important;
}

.dki-praxis-context-pill {
  font-size: 0.82rem !important;
  line-height: 1.42 !important;
  color: rgba(0,56,73,0.82) !important;
  white-space: normal;
  word-break: break-word;
}

/* ---------- chat history ---------- */

.dki-praxis-chat-history {
  flex: 1 1 auto !important;
  min-height: 0 !important;

  overflow-y: auto !important;

  padding: 15px !important;

  background:
    radial-gradient(circle at 12% 0%, rgba(167,201,0,0.10), transparent 32%),
    linear-gradient(180deg, #f8fafb 0%, #f2f5f6 100%) !important;
}

/* ---------- chat bubbles ---------- */

.dki-chat-bubble {
  max-width: 91% !important;

  margin: 10px 0 13px !important;
  padding: 13px 15px !important;

  border-radius: 19px !important;

  font-size: 0.92rem !important;
  line-height: 1.5 !important;

  box-shadow:
    0 8px 22px rgba(0, 56, 73, 0.06),
    inset 0 1px 0 rgba(255,255,255,0.86) !important;
}

.dki-chat-user {
  margin-left: auto !important;

  background:
    linear-gradient(180deg, rgba(167,201,0,0.18), rgba(167,201,0,0.10)) !important;

  color: var(--cpc-text) !important;

  border: 1px solid rgba(167,201,0,0.32) !important;
  border-left: 4px solid var(--cpc-green) !important;
}

.dki-chat-assistant {
  margin-right: auto !important;

  background: rgba(255,255,255,0.96) !important;

  color: var(--cpc-text) !important;

  border: 1px solid rgba(0,56,73,0.10) !important;
  border-left: 4px solid var(--cpc-ink-soft) !important;
}

.dki-chat-meta {
  margin-bottom: 6px !important;

  font-size: 0.70rem !important;
  font-weight: 750 !important;

  letter-spacing: 0.045em;
  text-transform: uppercase;

  color: rgba(0,56,73,0.58) !important;
}

/* ---------- markdown ---------- */

.dki-chat-markdown a {
  color: var(--cpc-ink-soft) !important;
  font-weight: 800;
  text-decoration: underline;
  text-underline-offset: 3px;
}

.dki-chat-markdown blockquote {
  border-left: 4px solid var(--cpc-green) !important;
  background: rgba(167,201,0,0.08) !important;
}

.dki-chat-markdown code {
  background: rgba(0,56,73,0.06) !important;
  color: var(--cpc-ink) !important;
}

.dki-chat-markdown pre {
  background: #ffffff !important;
  border: 1px solid rgba(0,56,73,0.10) !important;
  border-left: 4px solid var(--cpc-green) !important;
}

/* ---------- sources ---------- */

.praxis-chat-sources-compact {
  margin-top: 0.8rem;
  padding-top: 0.55rem;
  border-top: 1px solid rgba(0,56,73,0.10);
}

.praxis-chat-sources-title {
  font-size: 0.72rem;
  font-weight: 850;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: rgba(0,56,73,0.62);
}

.praxis-chat-source-pill,
.praxis-source-link,
.praxis-source-card {
  border: 1px solid rgba(0,56,73,0.10) !important;
  background: rgba(255,255,255,0.92) !important;
  color: var(--cpc-ink) !important;
  border-radius: 13px !important;
}

.praxis-chat-source-pill:hover,
.praxis-source-link:hover,
.praxis-source-card:hover {
  border-color: rgba(167,201,0,0.46) !important;
  box-shadow: 0 6px 18px rgba(0,56,73,0.08);
}

/* ---------- input area ---------- */

.dki-praxis-input-wrap {
  flex: 0 0 auto !important;

  padding: 11px 14px 13px !important;

  background: rgba(255,255,255,0.97) !important;

  border-top: 1px solid rgba(0,56,73,0.10) !important;

  box-shadow: 0 -12px 28px rgba(0,56,73,0.05) !important;
}

.dki-praxis-input-wrap textarea {
  width: 100% !important;

  min-height: 76px !important;
  max-height: 128px !important;

  resize: vertical !important;

  border-radius: 17px !important;

  border: 1px solid rgba(0,56,73,0.16) !important;

  background:
    linear-gradient(180deg, #ffffff, #fbfcfd) !important;

  color: var(--cpc-text) !important;

  padding: 12px 14px !important;

  font-size: 0.92rem !important;
  line-height: 1.5 !important;

  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.88) !important;
}

.dki-praxis-input-wrap textarea:focus {
  border-color: rgba(167,201,0,0.72) !important;

  box-shadow:
    0 0 0 4px rgba(167,201,0,0.16),
    inset 0 1px 0 rgba(255,255,255,0.9) !important;

  outline: none !important;
}

/* ---------- actions ---------- */

.dki-praxis-actions {
  display: flex !important;
  align-items: center !important;
  justify-content: flex-start !important;

  gap: 8px !important;

  padding-top: 8px !important;
}

.dki-praxis-actions .btn {
  min-height: 38px !important;
  height: 38px !important;

  border-radius: 13px !important;

  font-weight: 760 !important;

  transition:
    transform 0.14s ease,
    box-shadow 0.14s ease,
    border-color 0.14s ease,
    background 0.14s ease;
}

.dki-praxis-actions .btn-primary {
  min-width: 104px !important;

  background:
    linear-gradient(135deg, var(--cpc-ink), var(--cpc-ink-soft)) !important;

  border: 1px solid rgba(0,56,73,0.18) !important;

  color: #ffffff !important;

  box-shadow:
    0 8px 18px rgba(0,56,73,0.18),
    0 0 0 4px rgba(167,201,0,0.08) !important;
}

.dki-praxis-actions .btn-primary:hover {
  transform: translateY(-1px);

  box-shadow:
    0 11px 24px rgba(0,56,73,0.22),
    0 0 0 5px rgba(167,201,0,0.13) !important;
}

.dki-praxis-actions .btn-light {
  width: 38px !important;
  min-width: 38px !important;

  background: #ffffff !important;

  border: 1px solid rgba(0,56,73,0.12) !important;

  color: var(--cpc-ink) !important;

  box-shadow: 0 5px 14px rgba(0,56,73,0.06) !important;
}

.dki-praxis-actions .btn-light:hover {
  transform: translateY(-1px);
  border-color: rgba(167,201,0,0.52) !important;
  background: rgba(167,201,0,0.08) !important;
}

/* ---------- activity feed ---------- */

.praxis-activity-feed {
  margin: 10px 14px 0 !important;
  padding: 10px 12px !important;

  border-radius: 15px !important;

  background: rgba(167,201,0,0.10) !important;

  border: 1px solid rgba(167,201,0,0.22) !important;

  color: var(--cpc-ink) !important;
}

.praxis-activity-title {
  font-weight: 850 !important;
  font-size: 0.74rem !important;
  letter-spacing: 0.055em;
  text-transform: uppercase;
}

.praxis-activity-line {
  color: rgba(0,56,73,0.78) !important;
}

/* ---------- PRAXIS step/review buttons in CPC ---------- */

.praxis-step-btn,
.praxis-review-btn {
  border-radius: 13px !important;

  border: 1px solid rgba(0,56,73,0.16) !important;

  background:
    linear-gradient(#ffffff, #ffffff) padding-box,
    linear-gradient(135deg, rgba(0,56,73,0.55), rgba(167,201,0,0.72)) border-box !important;

  color: var(--cpc-ink) !important;

  box-shadow:
    0 7px 18px rgba(0,56,73,0.08),
    0 0 0 4px rgba(167,201,0,0.05) !important;
}

.praxis-step-btn:hover,
.praxis-review-btn:hover {
  transform: translateY(-1px);

  border-color: rgba(167,201,0,0.50) !important;

  box-shadow:
    0 10px 24px rgba(0,56,73,0.12),
    0 0 0 5px rgba(167,201,0,0.10) !important;
}

.praxis-mini-mark {
  background:
    linear-gradient(135deg, var(--cpc-ink), var(--cpc-ink-soft)) !important;

  color: #ffffff !important;
}

.praxis-wordmark {
  background:
    linear-gradient(135deg, var(--cpc-ink) 0%, var(--cpc-ink-soft) 58%, var(--cpc-green) 115%) !important;

  -webkit-background-clip: text !important;
  -webkit-text-fill-color: transparent !important;

  background-clip: text !important;
  color: transparent !important;
}

/* ---------- responsive ---------- */

@media (max-width: 1200px) {
  .dki-praxis-drawer {
    width: min(560px, calc(100vw - 32px)) !important;
    min-width: 340px;
  }

  .dki-praxis-shell.praxis-is-open .dki-praxis-sticky-container {
    right: min(560px + 22px, calc(100vw - 92px));
  }
}

@media (max-width: 768px) {
  .dki-praxis-drawer,
  .dki-praxis-drawer.is-expanded {
    top: 8px !important;
    right: 8px !important;
    bottom: 8px !important;
    left: 8px !important;

    width: auto !important;
    min-width: 0 !important;
    max-width: none !important;

    border-radius: 22px !important;
  }

  .dki-praxis-shell.praxis-is-open .dki-praxis-sticky-container {
    right: 16px;
    bottom: 16px;
  }

  .dki-praxis-btn {
    width: 76px !important;
    height: 76px !important;
    min-width: 76px !important;
    min-height: 76px !important;
    border-radius: 24px !important;
  }

  .dki-praxis-title {
    font-size: 20px !important;
  }

  .dki-praxis-input-wrap textarea {
    min-height: 58px !important;
    max-height: 92px !important;
    font-size: 16px !important;
    resize: none !important;
  }

  .dki-chat-bubble {
    max-width: 96% !important;
  }
}

/* =========================================================
   CPC PRAXIS LAUNCHER — REMOVE DKI RED HOVER
   MUST BE LAST
   ========================================================= */

.dki-praxis-btn,
.dki-praxis-btn:hover,
.dki-praxis-btn:focus,
.dki-praxis-btn:active {
  background:
    radial-gradient(
      circle at 28% 22%,
      rgba(255,255,255,0.98),
      rgba(255,255,255,0.86) 48%,
      rgba(246,247,248,0.96) 100%
    ) !important;

  border-color: rgba(167, 201, 0, 0.82) !important;

  box-shadow:
    0 18px 38px rgba(0, 56, 73, 0.18),
    inset 0 1px 0 rgba(255,255,255,0.88),
    0 0 0 7px rgba(167, 201, 0, 0.12) !important;

  color: var(--cpc-ink) !important;
}

.dki-praxis-btn:hover,
.dki-praxis-btn:focus {
  transform: translateY(-2px) scale(1.015);
  border-color: var(--cpc-green) !important;

  box-shadow:
    0 22px 48px rgba(0, 56, 73, 0.22),
    inset 0 1px 0 rgba(255,255,255,0.94),
    0 0 0 9px rgba(167, 201, 0, 0.18) !important;
}

.dki-praxis-btn svg,
.dki-praxis-btn svg *,
.dki-praxis-btn:hover svg,
.dki-praxis-btn:hover svg *,
.dki-praxis-btn:focus svg,
.dki-praxis-btn:focus svg * {
  fill: var(--cpc-ink) !important;
  stroke: var(--cpc-ink) !important;
  color: var(--cpc-ink) !important;
}