/* ============================================================================
 * CPWE AI — UI REFRESH LAYER (R24 P4.6 facelift)
 *
 * Purpose: tighten typography, sharpen edges, modernise focus rings
 * and button polish — without rewriting any existing stylesheet. This
 * file loads LAST in the cascade, so its rules override the older
 * design-system + guardian-style sheets where appropriate.
 *
 * Brand colors are PRESERVED (#0FD5C5 teal + #9B4DCA purple); the
 * refresh is about contrast, hierarchy, and tactile feedback.
 * ============================================================================ */

/* ---- 1. Token refinements (bolted onto :root, do not redefine wholesale) -- */
:root {
  /* Refined brand stops — slightly more saturated for sharper accent on dark */
  --cpwe-teal:        #0FD5C5;
  --cpwe-teal-2:      #0aa595;
  --cpwe-purple:      #9B4DCA;
  --cpwe-purple-2:    #c084fc;
  --cpwe-gold:        #FACC15;
  --cpwe-success:     #4ADE80;
  --cpwe-danger:      #FB7185;

  /* Sharper neutrals optimised for OLED-class contrast */
  --cpwe-ink-0:       #f0f6fc;
  --cpwe-ink-1:       #e6edf3;
  --cpwe-ink-2:       #c9d1d9;
  --cpwe-ink-3:       #adbac7;
  --cpwe-ink-4:       #9ba6b3;
  --cpwe-ink-5:       #6e7681;
  --cpwe-bg-0:        #0a0d12;
  --cpwe-bg-1:        #0d1117;
  --cpwe-bg-2:        #14191f;
  --cpwe-bg-3:        #1c2129;
  --cpwe-line:        rgba(255,255,255,0.07);
  --cpwe-line-soft:   rgba(255,255,255,0.04);

  /* Sharper, less-blurry shadows — defined edges instead of gauzy halos */
  --cpwe-shadow-sm:   0 1px 2px rgba(0,0,0,0.25);
  --cpwe-shadow-md:   0 4px 12px rgba(0,0,0,0.32),
                      0 1px 3px rgba(0,0,0,0.18);
  --cpwe-shadow-lg:   0 12px 28px rgba(0,0,0,0.4),
                      0 2px 6px rgba(0,0,0,0.22);
  --cpwe-shadow-glow-teal:   0 0 0 1px rgba(15,213,197,0.18),
                             0 12px 32px rgba(15,213,197,0.12);
  --cpwe-shadow-glow-purple: 0 0 0 1px rgba(155,77,202,0.18),
                             0 12px 32px rgba(155,77,202,0.12);

  /* Tighter motion — snappier than the ambient 300ms feel */
  --cpwe-motion-snap:  120ms cubic-bezier(0.32, 0.72, 0, 1);
  --cpwe-motion-flow:  220ms cubic-bezier(0.32, 0.72, 0, 1);

  /* Modern, slightly tighter line-heights for headings */
  --cpwe-lh-tight:     1.15;
  --cpwe-lh-snug:      1.35;
  --cpwe-lh-body:      1.55;
}

/* ---- 2. Typography polish (additive, no font-stack swap) ----------------- */
body {
  font-feature-settings: "ss01" on, "cv11" on, "tnum" off;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}
h1, h2, h3, .h1, .h2, .h3 {
  letter-spacing: -0.012em;
  line-height: var(--cpwe-lh-tight);
}
h4, h5, h6, .h4, .h5, .h6 {
  letter-spacing: -0.005em;
  line-height: var(--cpwe-lh-snug);
}
.lead, p.lead {
  font-weight: 400;
  letter-spacing: 0.005em;
  color: var(--cpwe-ink-3);
}
code, kbd, pre, samp, .font-mono {
  font-feature-settings: "calt" off, "liga" off;
}

/* Hairline divider helper — for the comparison/autospec layouts */
.cpwe-hairline {
  border: 0;
  height: 1px;
  background: linear-gradient(
    90deg,
    transparent,
    var(--cpwe-line) 20%,
    var(--cpwe-line) 80%,
    transparent
  );
}

/* ---- 3. Focus rings — accessible, branded, never default-browser-orange -- */
:where(a, button, input, select, textarea, [role="button"], [tabindex]):focus-visible {
  outline: none;
  box-shadow:
    0 0 0 2px var(--cpwe-bg-1),
    0 0 0 4px var(--cpwe-teal);
  border-radius: 6px;
  transition: box-shadow var(--cpwe-motion-snap);
}
/* Inputs get an inset glow as well so the field itself feels live */
:where(input, select, textarea):focus-visible {
  box-shadow:
    0 0 0 1px var(--cpwe-teal),
    0 0 0 4px rgba(15,213,197,0.18);
}

/* ---- 4. Bootstrap button refresh (additive) ------------------------------ */
.btn {
  font-weight: 600;
  letter-spacing: 0.005em;
  border-radius: 8px;
  transition: transform var(--cpwe-motion-snap),
              box-shadow var(--cpwe-motion-snap),
              background var(--cpwe-motion-snap),
              border-color var(--cpwe-motion-snap),
              color var(--cpwe-motion-snap);
}
.btn:hover { transform: translateY(-1px); }
.btn:active { transform: translateY(0); }
.btn:disabled { transform: none; opacity: 0.55; }
/* Suppress the lift in tight container contexts so neighboring elements
   don't visually shift on hover (input-groups, segmented btn-groups, and
   table-cell buttons all keep a static y-position). */
.input-group .btn:hover,
.btn-group .btn:hover,
.btn-group-vertical .btn:hover,
.btn-toolbar .btn:hover,
td .btn:hover,
th .btn:hover { transform: none; }

.btn-primary,
.btn-success,
.btn-info,
.btn-cpwe-teal {
  background: linear-gradient(135deg, var(--cpwe-teal) 0%, var(--cpwe-teal-2) 100%);
  border: 0;
  color: var(--cpwe-bg-1);
}
.btn-primary:hover,
.btn-success:hover,
.btn-info:hover,
.btn-cpwe-teal:hover {
  box-shadow: 0 8px 22px rgba(15,213,197,0.3);
  color: var(--cpwe-bg-1);
}

.btn-secondary,
.btn-cpwe-purple {
  background: linear-gradient(135deg, var(--cpwe-purple) 0%, #7c3aed 100%);
  border: 0;
  color: var(--cpwe-ink-0);
}
.btn-secondary:hover,
.btn-cpwe-purple:hover {
  box-shadow: 0 8px 22px rgba(155,77,202,0.3);
  color: var(--cpwe-ink-0);
}

.btn-outline-primary,
.btn-outline-secondary,
.btn-outline-light,
.btn-outline-info,
.btn-cpwe-ghost {
  background: rgba(255,255,255,0.025);
  border: 1px solid rgba(255,255,255,0.1);
  color: var(--cpwe-ink-2);
}
.btn-outline-primary:hover,
.btn-outline-info:hover,
.btn-cpwe-ghost:hover {
  background: rgba(15,213,197,0.08);
  border-color: rgba(15,213,197,0.45);
  color: var(--cpwe-teal);
}
.btn-outline-secondary:hover {
  background: rgba(155,77,202,0.08);
  border-color: rgba(155,77,202,0.45);
  color: var(--cpwe-purple-2);
}

/* ---- 5. Card refresh (additive) ------------------------------------------ */
.card,
.glass-card,
.dashboard-card {
  border-radius: 12px;
  border-color: var(--cpwe-line);
  background: linear-gradient(165deg, var(--cpwe-bg-1) 0%, var(--cpwe-bg-2) 100%);
  transition: transform var(--cpwe-motion-flow),
              border-color var(--cpwe-motion-flow),
              box-shadow var(--cpwe-motion-flow);
}
.card:hover,
.dashboard-card:hover {
  border-color: rgba(15,213,197,0.22);
}
.card-header,
.card-footer {
  background: transparent;
  border-color: var(--cpwe-line);
}

/* Sharper numeric callouts */
.metric-value,
.stat-number,
.cmp-metric-value,
.as-stat-num {
  font-variant-numeric: tabular-nums;
  font-feature-settings: "tnum" on, "lnum" on;
  letter-spacing: -0.015em;
}

/* ---- 6. Form-control refresh --------------------------------------------- */
.form-control,
.form-select {
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.1);
  color: var(--cpwe-ink-1);
  border-radius: 8px;
  transition: border-color var(--cpwe-motion-snap),
              background var(--cpwe-motion-snap);
}
.form-control:focus,
.form-select:focus {
  background: rgba(255,255,255,0.05);
  border-color: var(--cpwe-teal);
  color: var(--cpwe-ink-0);
}
.form-control::placeholder { color: var(--cpwe-ink-5); }

/* ---- 7. Badge / pill refresh --------------------------------------------- */
.badge {
  font-weight: 700;
  letter-spacing: 0.04em;
  border-radius: 999px;
  padding: 0.32em 0.7em;
}

/* ---- 8. Subtle scrollbar polish (webkit + firefox) ----------------------- */
* { scrollbar-width: thin; scrollbar-color: rgba(255,255,255,0.14) transparent; }
*::-webkit-scrollbar { width: 9px; height: 9px; }
*::-webkit-scrollbar-thumb {
  background: rgba(255,255,255,0.12);
  border-radius: 999px;
  transition: background 0.15s;
}
*::-webkit-scrollbar-thumb:hover { background: rgba(15,213,197,0.4); }
*::-webkit-scrollbar-track { background: transparent; }

/* ---- 9. Selection color ------------------------------------------------- */
::selection {
  background: rgba(15,213,197,0.32);
  color: var(--cpwe-ink-0);
}

/* ---- 10. Reduced-motion respect ----------------------------------------- */
@media (prefers-reduced-motion: reduce) {
  .btn:hover { transform: none; }
  .card:hover, .dashboard-card:hover { transform: none; }
  *,
  *::before,
  *::after {
    animation-duration: 0.001ms !important;
    transition-duration: 0.001ms !important;
  }
}

/* ---- 11. High-contrast mode polish (already in base.html via data attr) -- */
html[data-high-contrast="true"] .btn {
  border-width: 2px;
}
html[data-high-contrast="true"] :focus-visible {
  box-shadow:
    0 0 0 3px var(--cpwe-bg-0),
    0 0 0 6px var(--cpwe-teal) !important;
}
