/*
 * CONVERSION AUTHORITY THEME — AI Evolution
 * Psychological marketing color system applied site-wide
 *
 * Principles:
 *   #0b1220  Deep Navy     → authority, trust, expertise (backgrounds)
 *   #0f172a  Authority Navy → card surfaces, secondary depth
 *   #f59e0b  Conversion Amber → action, urgency, forward momentum (CTAs, accents)
 *   #10b981  Success Green  → safety, growth, positive completion
 *   #f8fafc  Clarity White  → cognitive ease, primary text
 *   #cbd5e1  Body Text      → readable without harshness
 *   #64748b  Muted Slate    → supporting detail, hierarchy signal
 */

/* ── Token overrides ── */
:root {
  --ca-navy:        #0b1220;
  --ca-navy-card:   #0f172a;
  --ca-amber:       #f59e0b;
  --ca-amber-dim:   rgba(245,158,11,0.12);
  --ca-amber-hover: #e08e00;
  --ca-green:       #10b981;
  --ca-white:       #f8fafc;
  --ca-body:        #cbd5e1;
  --ca-slate:       #64748b;
  --ca-border:      rgba(248,250,252,0.08);

  /* Override existing brand tokens to match Conversion Authority */
  --brand-bg:        #0b1220;
  --brand-surface:   #0f172a;
  --brand-surface-2: #1e293b;
  --brand-gold:      #f59e0b;
  --brand-gold-dim:  rgba(245,158,11,0.12);
  --brand-ink:       #f8fafc;
  --color-bg:        #0b1220;
  --color-surface:   #0f172a;
  --color-text:      #f8fafc;
  --color-muted:     #64748b;
  --color-border:    rgba(248,250,252,0.08);

  /* Bootstrap tokens */
  --bs-body-bg:      #0b1220;
  --bs-body-color:   #cbd5e1;
  --bs-warning:      #f59e0b;
  --bs-warning-rgb:  245,158,11;
}

/* ── Base ── */
body {
  font-family: 'Inter', system-ui, -apple-system, sans-serif !important;
  background: var(--ca-navy) !important;
  color: var(--ca-body) !important;
  -webkit-font-smoothing: antialiased;
}

/* ── Navigation ── */
.navbar,
.site-nav {
  background: var(--ca-navy-card) !important;
  border-bottom: 1px solid rgba(248,250,252,0.07) !important;
}
.navbar-brand {
  color: var(--ca-white) !important;
  font-weight: 800 !important;
  letter-spacing: -0.02em !important;
}
.navbar-brand:hover { color: var(--ca-amber) !important; }

.nav-link {
  color: rgba(248,250,252,0.65) !important;
  font-weight: 500 !important;
  font-size: 0.875rem !important;
  transition: color 0.15s ease !important;
}
.nav-link:hover,
.nav-link:focus { color: var(--ca-amber) !important; }
.nav-link.active { color: var(--ca-amber) !important; }

.navbar-toggler {
  border-color: rgba(248,250,252,0.2) !important;
}
.navbar-toggler-icon { filter: invert(1) opacity(0.7); }

/* ── Hero sections ── */
.hero {
  background: linear-gradient(135deg, var(--ca-navy) 0%, #0d1829 100%) !important;
  color: var(--ca-white) !important;
  border-bottom: 3px solid var(--ca-amber) !important;
}
.hero h1,
.hero .display-6,
.hero .display-5 {
  color: var(--ca-white) !important;
  font-weight: 800 !important;
  letter-spacing: -0.03em !important;
}
.hero .lead { color: rgba(248,250,252,0.85) !important; }
.hero .text-muted,
.hero small { color: rgba(248,250,252,0.45) !important; }
.hero .badge.bg-warning,
.hero .badge.bg-secondary {
  font-weight: 700 !important;
  letter-spacing: 0.04em !important;
  text-transform: uppercase !important;
  font-size: 0.68rem !important;
}
.hero .badge.bg-warning {
  background: var(--ca-amber) !important;
  color: var(--ca-navy-card) !important;
}

/* ── Cards ── */
.card {
  background: var(--ca-navy-card) !important;
  border: 1px solid var(--ca-border) !important;
  border-radius: 12px !important;
  box-shadow: 0 4px 24px rgba(0,0,0,0.35), 0 1px 4px rgba(0,0,0,0.2) !important;
  color: var(--ca-body) !important;
}
.card:hover { border-color: rgba(245,158,11,0.2) !important; }
.card-title,
.card-body h2,
.card-body h3 {
  color: var(--ca-white) !important;
  font-weight: 700 !important;
}
.card-body .text-muted { color: var(--ca-slate) !important; }

/* ── Buttons ── */
.btn-warning {
  background: var(--ca-amber) !important;
  border-color: var(--ca-amber) !important;
  color: var(--ca-navy-card) !important;
  font-weight: 700 !important;
  letter-spacing: 0.01em !important;
  transition: background 0.15s, transform 0.1s !important;
}
.btn-warning:hover,
.btn-warning:focus {
  background: var(--ca-amber-hover) !important;
  border-color: var(--ca-amber-hover) !important;
  color: var(--ca-navy-card) !important;
  transform: translateY(-1px);
}
.btn-warning:active { transform: translateY(0); }

.btn-outline-primary {
  border-color: rgba(245,158,11,0.4) !important;
  color: var(--ca-amber) !important;
}
.btn-outline-primary:hover {
  background: var(--ca-amber) !important;
  border-color: var(--ca-amber) !important;
  color: var(--ca-navy-card) !important;
}

.btn-outline-secondary {
  border-color: rgba(248,250,252,0.2) !important;
  color: rgba(248,250,252,0.75) !important;
}
.btn-outline-secondary:hover {
  background: rgba(248,250,252,0.08) !important;
  color: var(--ca-white) !important;
}

.btn-primary {
  background: var(--ca-amber) !important;
  border-color: var(--ca-amber) !important;
  color: var(--ca-navy-card) !important;
  font-weight: 700 !important;
}
.btn-primary:hover {
  background: var(--ca-amber-hover) !important;
  border-color: var(--ca-amber-hover) !important;
  color: var(--ca-navy-card) !important;
}

/* ── Headings (general) ── */
h1, h2, h3, h4, h5, h6 { color: var(--ca-white) !important; }
.text-muted { color: var(--ca-slate) !important; }
.lead { color: rgba(248,250,252,0.8) !important; }

/* ── Section headings with eyebrow class ── */
.section-heading { color: var(--ca-white) !important; }
.decision-guide__eyebrow,
.small.text-uppercase { color: var(--ca-amber) !important; letter-spacing: 0.06em !important; }

/* ── Badges ── */
.badge.bg-warning { background: var(--ca-amber) !important; color: var(--ca-navy-card) !important; }
.badge.bg-secondary { background: rgba(248,250,252,0.1) !important; color: rgba(248,250,252,0.7) !important; }
.badge.bg-dark { background: rgba(248,250,252,0.07) !important; color: rgba(248,250,252,0.6) !important; }

/* ── Surfaces / section backgrounds ── */
.bg-light,
[style*="background: var(--brand-surface)"],
[style*="background:var(--brand-surface)"] {
  background: var(--ca-navy-card) !important;
  color: var(--ca-body) !important;
}
.bg-dark { background: #050c18 !important; }

/* ── Bootstrap list groups ── */
.list-group-item {
  background: var(--ca-navy-card) !important;
  border-color: var(--ca-border) !important;
  color: var(--ca-body) !important;
}

/* ── Forms / inputs ── */
.form-control,
.form-select {
  background: rgba(248,250,252,0.05) !important;
  border-color: var(--ca-border) !important;
  color: var(--ca-white) !important;
}
.form-control::placeholder { color: var(--ca-slate) !important; }
.form-control:focus {
  background: rgba(248,250,252,0.08) !important;
  border-color: var(--ca-amber) !important;
  box-shadow: 0 0 0 3px rgba(245,158,11,0.2) !important;
  color: var(--ca-white) !important;
}
label { color: var(--ca-body) !important; }

/* ── Tables ── */
.table { color: var(--ca-body) !important; }
.table thead th { color: var(--ca-amber) !important; border-color: var(--ca-border) !important; }
.table td, .table th { border-color: var(--ca-border) !important; }

/* ── Accordion ── */
.accordion-item {
  background: var(--ca-navy-card) !important;
  border-color: var(--ca-border) !important;
}
.accordion-button {
  background: var(--ca-navy-card) !important;
  color: var(--ca-white) !important;
  font-weight: 600 !important;
}
.accordion-button:not(.collapsed) {
  background: rgba(245,158,11,0.08) !important;
  color: var(--ca-amber) !important;
  box-shadow: none !important;
}
.accordion-button::after { filter: invert(1) opacity(0.5); }
.accordion-button:not(.collapsed)::after { filter: invert(0.9) sepia(1) saturate(3) hue-rotate(5deg); }
.accordion-body { color: var(--ca-body) !important; }

/* ── Links ── */
a:not(.btn):not(.nav-link):not(.navbar-brand) { color: var(--ca-amber) !important; }
a:not(.btn):not(.nav-link):not(.navbar-brand):hover { color: var(--ca-amber-hover) !important; }

/* ── Horizontal rules / dividers ── */
hr { border-color: var(--ca-border) !important; opacity: 1 !important; }
.border-top { border-color: var(--ca-border) !important; }

/* ── Icon accent colours ── */
.bi.text-warning,
.text-warning { color: var(--ca-amber) !important; }
.text-success { color: var(--ca-green) !important; }
.text-primary { color: var(--ca-amber) !important; }

/* ── Sticky sidebar cards ── */
aside .card,
.position-sticky .card {
  border-left: 3px solid var(--ca-amber) !important;
}

/* ── CTA blocks ── */
.cta-block,
section.text-center.bg-light,
section[aria-label="Call to action"] {
  background: linear-gradient(135deg, var(--ca-navy-card) 0%, #0d1829 100%) !important;
  border: 1px solid rgba(245,158,11,0.15) !important;
  border-radius: 12px !important;
  color: var(--ca-white) !important;
}
section.text-center.bg-light h2,
section[aria-label="Call to action"] h2 {
  color: var(--ca-white) !important;
}
section.text-center.bg-light .text-muted,
section[aria-label="Call to action"] .text-muted {
  color: rgba(248,250,252,0.6) !important;
}

/* ── Footer ── */
footer.bg-dark {
  background: #040a14 !important;
  border-top: 1px solid rgba(248,250,252,0.05) !important;
}
footer .link-light { color: rgba(248,250,252,0.5) !important; }
footer .link-light:hover { color: var(--ca-amber) !important; }

/* ── Skip link ── */
.skip-link {
  position: absolute;
  left: -9999px;
  top: 0;
  background: var(--ca-amber);
  color: var(--ca-navy-card);
  padding: 0.5rem 1rem;
  font-weight: 700;
  z-index: 9999;
  border-radius: 0 0 6px 0;
}
.skip-link:focus { left: 0; }

/* ── Scrollbar ── */
::-webkit-scrollbar { width: 8px; }
::-webkit-scrollbar-track { background: var(--ca-navy); }
::-webkit-scrollbar-thumb { background: rgba(245,158,11,0.3); border-radius: 4px; }
::-webkit-scrollbar-thumb:hover { background: rgba(245,158,11,0.5); }

/* ── Focus ring ── */
:focus-visible { outline: 2px solid var(--ca-amber) !important; outline-offset: 3px !important; }

/* ── Before/After Slider ── */
.ba-container {
  position: relative;
  border-radius: 10px;
  overflow: hidden;
  min-height: 240px;
  cursor: ew-resize;
}
.ba-panel {
  padding: 1.25rem 1.35rem;
  min-height: 240px;
  border-radius: 10px;
}
.ba-before {
  background: rgba(220,38,38,0.07);
  border: 1px solid rgba(220,38,38,0.18);
}
.ba-after {
  position: absolute;
  top: 0; left: 0; right: 0; bottom: 0;
  background: #0d1f16;
  border: 1px solid rgba(16,185,129,0.25);
  clip-path: inset(0 50% 0 0);
  border-radius: 10px;
}
.ba-label {
  font-size: 0.65rem;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 0.2em 0.65em;
  border-radius: 20px;
  display: inline-block;
  margin-bottom: 0.6rem;
}
.ba-label-before { background: rgba(220,38,38,0.18); color: #f87171; }
.ba-label-after  { background: rgba(16,185,129,0.18); color: #34d399; }
.ba-scenario {
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--ca-white);
  margin-bottom: 0.6rem;
}
.ba-list {
  list-style: none;
  padding: 0;
  margin: 0;
}
.ba-list li {
  font-size: 0.84rem;
  color: var(--ca-body);
  padding: 0.3rem 0;
  border-bottom: 1px solid rgba(248,250,252,0.06);
}
.ba-list li:last-child { border-bottom: none; }
.ba-track {
  position: absolute;
  top: 0; left: 0; right: 0; bottom: 0;
  pointer-events: none;
  z-index: 5;
}
.ba-divider {
  position: absolute;
  top: 0; bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 2px;
  background: var(--ca-amber);
  display: flex;
  align-items: center;
  justify-content: center;
}
.ba-pill {
  background: var(--ca-amber);
  color: var(--ca-navy);
  font-size: 0.7rem;
  font-weight: 800;
  padding: 0.3em 0.55em;
  border-radius: 20px;
  white-space: nowrap;
  box-shadow: 0 2px 8px rgba(0,0,0,0.3);
}
.ba-range {
  position: absolute;
  top: 0; left: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  cursor: ew-resize;
  z-index: 10;
  margin: 0;
}

/* ── Quiz answer cards (which-workshop.html) ── */
.quiz-option {
  background: var(--ca-navy-card);
  border: 2px solid rgba(248,250,252,0.08);
  border-radius: 10px;
  padding: 0.85rem 1rem;
  cursor: pointer;
  transition: border-color 0.15s, background 0.15s;
  display: flex;
  align-items: center;
  gap: 0.75rem;
}
.quiz-option:hover {
  border-color: rgba(245,158,11,0.4);
  background: rgba(245,158,11,0.05);
}
.quiz-option.selected {
  border-color: var(--ca-amber) !important;
  background: rgba(245,158,11,0.1) !important;
}
.quiz-option input[type="radio"] { display: none; }
.quiz-check {
  width: 20px; height: 20px;
  border: 2px solid rgba(248,250,252,0.25);
  border-radius: 50%;
  flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  font-size: 0.65rem;
  transition: all 0.15s;
}
.quiz-option.selected .quiz-check {
  background: var(--ca-amber);
  border-color: var(--ca-amber);
  color: var(--ca-navy);
}

/* ── Workshop Simulator ── */
.sim-card {
  background: var(--ca-navy-card);
  border: 1px solid rgba(248,250,252,0.08);
  border-radius: 12px;
  padding: 1.35rem;
}
.sim-step-label {
  font-size: 0.65rem;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ca-amber);
  margin-bottom: 0.4rem;
}
.sim-question {
  font-size: 1rem;
  font-weight: 700;
  color: var(--ca-white);
  margin-bottom: 0.75rem;
  line-height: 1.4;
}
.sim-reveal-btn {
  background: rgba(245,158,11,0.12);
  border: 1px solid rgba(245,158,11,0.3);
  color: var(--ca-amber);
  border-radius: 8px;
  padding: 0.55rem 1rem;
  font-size: 0.875rem;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.15s;
}
.sim-reveal-btn:hover { background: rgba(245,158,11,0.2); }
.sim-answer {
  margin-top: 0.75rem;
  padding: 0.85rem 1rem;
  background: rgba(16,185,129,0.08);
  border: 1px solid rgba(16,185,129,0.2);
  border-radius: 8px;
  color: var(--ca-body);
  font-size: 0.9rem;
  line-height: 1.6;
}
.sim-next-btn {
  margin-top: 0.75rem;
  background: var(--ca-amber);
  color: var(--ca-navy);
  border: none;
  border-radius: 8px;
  padding: 0.55rem 1.25rem;
  font-size: 0.875rem;
  font-weight: 700;
  cursor: pointer;
  transition: background 0.15s;
}
.sim-next-btn:hover { background: #e08e00; }
.sim-progress-dots {
  display: flex;
  gap: 0.4rem;
  margin-bottom: 1rem;
}
.sim-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: rgba(248,250,252,0.15);
  transition: background 0.2s;
}
.sim-dot.active { background: var(--ca-amber); }
.sim-dot.done   { background: var(--ca-green); }

/* ── Phase 5: 5 CSS micro-animations (prefers-reduced-motion safe) ── */
@media (prefers-reduced-motion: no-preference) {

  /* 1. Card hover — amber left-border glow */
  .card {
    transition: box-shadow 180ms ease, border-color 180ms ease, transform 180ms ease !important;
  }
  .card:hover {
    box-shadow: 0 0 0 1px var(--ca-amber), 0 8px 32px rgba(0,0,0,0.35) !important;
    transform: translateY(-1px);
  }

  /* 2. CTA button hover — lift + deepen */
  .btn-warning, .btn-outline-primary, .btn-outline-secondary {
    transition: transform 150ms ease, box-shadow 150ms ease, background 150ms ease, color 150ms ease, border-color 150ms ease !important;
  }
  .btn-warning:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 16px rgba(245,158,11,0.35) !important;
  }
  .btn-outline-primary:hover, .btn-outline-secondary:hover {
    transform: translateY(-1px);
  }

  /* 3. Section scroll reveal — fade-up via Intersection Observer JS hook */
  .ca-reveal {
    opacity: 0;
    transform: translateY(18px);
    transition: opacity 420ms ease-out, transform 420ms ease-out;
  }
  .ca-reveal.visible {
    opacity: 1;
    transform: translateY(0);
  }

  /* 4. Nav link underline slide */
  .nav-link {
    position: relative;
    padding-bottom: 2px !important;
  }
  .nav-link::after {
    content: '';
    position: absolute;
    bottom: 0; left: 0;
    width: 0; height: 2px;
    background: var(--ca-amber);
    transition: width 200ms ease;
  }
  .nav-link:hover::after,
  .nav-link.active::after { width: 100%; }

  /* 5. Hero CTA — single entry pulse on page load */
  @keyframes ctaPulse {
    0%   { box-shadow: 0 0 0 0 rgba(245,158,11,0.5); }
    70%  { box-shadow: 0 0 0 10px rgba(245,158,11,0); }
    100% { box-shadow: 0 0 0 0 rgba(245,158,11,0); }
  }
  .hero .btn-warning {
    animation: ctaPulse 1.8s ease-out 1.2s 1;
  }
}

/* Scroll reveal JS helper — add to sections via JS */

/* ── Print ── */
@media print {
  body { background: white !important; color: #111 !important; }
  .navbar, footer { display: none !important; }
  .hero { background: none !important; border: none !important; color: #000 !important; }
  .card { background: white !important; border: 1px solid #ddd !important; box-shadow: none !important; }
  h1, h2, h3, h4, h5, h6 { color: #000 !important; }
  a { color: #000 !important; }
}
