/* ═════════════════════════════════════════════════════════════════════════════
   js/commission-v2.css — WIP-UI-COMMISSION-01 Phase 1
   Three pulsing money cards + motivation strip + role gating + team rollup.
   Classes namespaced .cm2-* to avoid collisions with existing 24-commission.js
   styles. Existing tab/handler markup is preserved verbatim by the renderer.
   ═════════════════════════════════════════════════════════════════════════════ */

:root {
  --cm2-ok-fg: #15803D;
  --cm2-ok-deep: #166534;
  --cm2-ok-light: #22C55E;
  --cm2-due-fg: #DC2626;
  --cm2-due-deep: #991B1B;
  --cm2-due-bg: #FEE2E2;
  --cm2-pending-fg: #D97706;
  --cm2-pending-deep: #92400E;
  --cm2-pending-bg: #FEF3C7;
}

/* ─── Pulse keyframes ───────────────────────────────────────────────── */
@keyframes cm2-pulse-paid {
  0%, 100% { box-shadow: 0 0 0 0 rgba(21,128,61,.35), 0 4px 14px -4px rgba(21,128,61,.4); }
  50%      { box-shadow: 0 0 0 10px rgba(21,128,61,0), 0 8px 20px -4px rgba(21,128,61,.55); }
}
@keyframes cm2-pulse-due {
  0%, 100% { box-shadow: 0 0 0 0 rgba(220,38,38,.5), 0 4px 14px -4px rgba(220,38,38,.5); }
  50%      { box-shadow: 0 0 0 14px rgba(220,38,38,0), 0 8px 22px -4px rgba(220,38,38,.65); }
}
@keyframes cm2-pulse-pending {
  0%, 100% { box-shadow: 0 0 0 0 rgba(245,158,11,.35), 0 4px 14px -4px rgba(217,119,6,.4); }
  50%      { box-shadow: 0 0 0 10px rgba(245,158,11,0), 0 8px 20px -4px rgba(217,119,6,.5); }
}
@keyframes cm2-glow-due-text {
  0%, 100% { text-shadow: 0 0 0 rgba(220,38,38,0); }
  50%      { text-shadow: 0 0 18px rgba(220,38,38,.35); }
}
@keyframes cm2-shimmer {
  0%   { background-position: -200% 0; }
  100% { background-position:  200% 0; }
}
@media (prefers-reduced-motion: reduce) {
  .cm2-page .money-card.pulse-paid,
  .cm2-page .money-card.pulse-due,
  .cm2-page .money-card.pulse-pending,
  .cm2-page .money-num.glow-due,
  .cm2-page .cm2-motivation::before {
    animation: none !important;
  }
}

/* ─── Page chassis ──────────────────────────────────────────────────── */
.cm2-page { padding: 4px 0 32px; font-family: 'Archivo', system-ui, sans-serif; }

/* ─── Hero ──────────────────────────────────────────────────────────── */
.cm2-page .cm2-hero {
  display: flex; align-items: flex-end; justify-content: space-between;
  gap: 24px; margin-bottom: 22px; padding-bottom: 20px;
  border-bottom: 1px solid var(--s200, #E7E5E4); flex-wrap: wrap;
}
.cm2-page .cm2-hero-l { display: flex; flex-direction: column; gap: 8px; }
.cm2-page .cm2-hero-eyebrow {
  font-size: 11px; font-weight: 800; letter-spacing: 0.24em;
  text-transform: uppercase; color: var(--s500, #78716C);
  display: flex; align-items: center; gap: 8px;
}
.cm2-page .cm2-hero-eyebrow .you-pill {
  padding: 2px 8px; background: var(--ok-bg, #DCFCE7); color: var(--cm2-ok-fg);
  border-radius: 5px; font-size: 10px; font-weight: 800;
  letter-spacing: 0.06em; display: inline-flex; align-items: center;
  gap: 4px; text-transform: uppercase;
}
.cm2-page .cm2-hero-title {
  font-size: 42px; font-weight: 900; letter-spacing: -0.045em;
  color: var(--ink, #0A0A0A); line-height: 1;
}
.cm2-page .cm2-hero-sub {
  font-size: 16px; font-weight: 700; color: var(--s500, #78716C);
  font-variant-numeric: tabular-nums; margin-top: 6px;
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
}
.cm2-page .cm2-hero-sub .rep-chip {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 3px 9px 3px 4px; background: #fff;
  border: 1px solid var(--s200, #E7E5E4); border-radius: 7px;
  font-size: 12px; font-weight: 700; color: var(--ink, #0A0A0A);
}
.cm2-page .cm2-hero-sub .rep-chip-av {
  width: 18px; height: 18px; border-radius: 4px;
  background: var(--cm2-ok-fg); color: #fff; font-size: 9px;
  font-weight: 800; display: inline-flex; align-items: center;
  justify-content: center;
}
.cm2-page .cm2-hero-sub .rate-chip {
  padding: 3px 9px; background: var(--info-bg, #DBEAFE);
  color: var(--info-fg, #1D4ED8); border-radius: 7px;
  font-size: 11px; font-weight: 800; letter-spacing: 0.02em;
}
.cm2-page .cm2-hero-r { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }

.cm2-page .cm2-period-tabs {
  display: inline-flex; background: #fff;
  border: 1px solid var(--s200, #E7E5E4); border-radius: 11px;
  padding: 3px; gap: 2px; box-shadow: var(--shadow-rest);
}
.cm2-page .cm2-period-tab {
  padding: 8px 16px; font-size: 12px; font-weight: 700;
  color: var(--s500, #78716C); border-radius: 8px; cursor: pointer;
  letter-spacing: -0.005em; border: none; background: none;
  font-family: inherit; transition: all 180ms cubic-bezier(.4,0,.2,1);
}
.cm2-page .cm2-period-tab:hover { color: var(--ink, #0A0A0A); }
.cm2-page .cm2-period-tab.on {
  background: var(--ink, #0A0A0A); color: #fff;
  box-shadow: 0 1px 2px rgba(10,10,10,.15);
}

/* ─── Money cards — the emotional anchor ───────────────────────────── */
.cm2-page .money-row {
  display: grid; grid-template-columns: 1fr 1.2fr 1fr;
  gap: 18px; margin-bottom: 22px;
}
@media (max-width: 1100px) { .cm2-page .money-row { grid-template-columns: 1fr; } }

.cm2-page .money-card {
  padding: 24px 22px 22px; border-radius: 18px; background: #fff;
  border: 1.5px solid var(--s200, #E7E5E4); position: relative;
  overflow: hidden; cursor: pointer;
  transition: transform 180ms cubic-bezier(.4,0,.2,1);
}
.cm2-page .money-card:hover { transform: translateY(-3px); }
.cm2-page .money-card::after {
  content: ''; position: absolute; left: 0; right: 0; top: 0; bottom: 0;
  background: radial-gradient(ellipse at top right, var(--cm2-accent-soft, transparent) 0%, transparent 60%);
  pointer-events: none;
}

.cm2-page .money-card.paid {
  border-color: rgba(21,128,61,.35);
  background: linear-gradient(180deg, #fff 0%, rgba(21,128,61,.04) 100%);
  --cm2-accent-soft: rgba(21,128,61,.08);
}
.cm2-page .money-card.paid.pulse-paid { animation: cm2-pulse-paid 2.4s ease-in-out infinite; }

.cm2-page .money-card.due {
  border-color: rgba(220,38,38,.45);
  background: linear-gradient(180deg, #fff 0%, rgba(220,38,38,.05) 100%);
  border-width: 2px; transform: scale(1.02);
  --cm2-accent-soft: rgba(220,38,38,.1);
}
.cm2-page .money-card.due:hover { transform: scale(1.02) translateY(-3px); }
.cm2-page .money-card.due.pulse-due { animation: cm2-pulse-due 1.8s ease-in-out infinite; }

.cm2-page .money-card.pending {
  border-color: rgba(245,158,11,.35);
  background: linear-gradient(180deg, #fff 0%, rgba(245,158,11,.04) 100%);
  --cm2-accent-soft: rgba(245,158,11,.08);
}
.cm2-page .money-card.pending.pulse-pending { animation: cm2-pulse-pending 2.4s ease-in-out infinite; }

.cm2-page .money-eyebrow {
  font-size: 10.5px; font-weight: 800; letter-spacing: 0.22em;
  text-transform: uppercase; display: flex; align-items: center;
  gap: 8px; margin-bottom: 14px;
}
.cm2-page .money-card.paid .money-eyebrow { color: var(--cm2-ok-deep); }
.cm2-page .money-card.due .money-eyebrow { color: var(--cm2-due-deep); }
.cm2-page .money-card.pending .money-eyebrow { color: var(--cm2-pending-deep); }
.cm2-page .money-eyebrow .status-dot {
  width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0;
}
.cm2-page .money-card.paid .status-dot { background: var(--cm2-ok-fg); box-shadow: 0 0 8px rgba(21,128,61,.5); }
.cm2-page .money-card.due .status-dot { background: var(--cm2-due-fg); box-shadow: 0 0 10px rgba(220,38,38,.7); }
.cm2-page .money-card.pending .status-dot { background: var(--cm2-pending-fg); box-shadow: 0 0 8px rgba(245,158,11,.5); }

.cm2-page .money-num {
  font-size: 48px; font-weight: 900; letter-spacing: -0.045em;
  line-height: 1; font-variant-numeric: tabular-nums;
  display: flex; align-items: baseline; gap: 8px;
}
.cm2-page .money-card.paid .money-num { color: var(--cm2-ok-fg); }
.cm2-page .money-card.due .money-num { color: var(--cm2-due-fg); font-size: 56px; }
.cm2-page .money-card.due .money-num.glow-due { animation: cm2-glow-due-text 1.8s ease-in-out infinite; }
.cm2-page .money-card.pending .money-num { color: var(--cm2-pending-fg); }
.cm2-page .money-num .unit {
  font-size: 14px; font-weight: 700;
  color: var(--s500, #78716C); letter-spacing: 0.02em;
}

.cm2-page .money-sub {
  font-size: 13px; font-weight: 700; margin-top: 10px;
  display: flex; align-items: center; gap: 6px; letter-spacing: -0.005em;
}
.cm2-page .money-card.paid .money-sub { color: var(--cm2-ok-deep); }
.cm2-page .money-card.due .money-sub { color: var(--cm2-due-deep); }
.cm2-page .money-card.pending .money-sub { color: var(--cm2-pending-deep); }
.cm2-page .money-sub b { font-weight: 900; }

.cm2-page .money-foot {
  margin-top: 14px; padding-top: 14px;
  border-top: 1px dashed var(--s200, #E7E5E4);
  display: flex; align-items: center; justify-content: space-between;
  gap: 8px; position: relative; z-index: 1;
}
.cm2-page .money-foot-meta {
  font-size: 11px; color: var(--s500, #78716C);
  font-weight: 700; letter-spacing: 0.02em;
}
.cm2-page .money-foot-meta b { color: var(--ink, #0A0A0A); font-weight: 800; }
.cm2-page .money-foot-action {
  font-size: 11.5px; font-weight: 800; display: inline-flex;
  align-items: center; gap: 4px; padding: 4px 9px; border-radius: 6px;
  cursor: pointer; transition: all 180ms cubic-bezier(.4,0,.2,1);
  letter-spacing: -0.005em; border: none; font-family: inherit;
}
.cm2-page .money-card.paid .money-foot-action { color: var(--cm2-ok-fg); background: rgba(21,128,61,.08); }
.cm2-page .money-card.paid .money-foot-action:hover { background: var(--cm2-ok-fg); color: #fff; }
.cm2-page .money-card.due .money-foot-action { color: #fff; background: var(--cm2-due-fg); }
.cm2-page .money-card.due .money-foot-action:hover { background: var(--cm2-due-deep); }
.cm2-page .money-card.pending .money-foot-action { color: var(--cm2-pending-fg); background: rgba(245,158,11,.1); }
.cm2-page .money-card.pending .money-foot-action:hover { background: var(--cm2-pending-fg); color: #fff; }

/* ─── Motivation strip ─────────────────────────────────────────────── */
.cm2-page .cm2-motivation {
  background: linear-gradient(135deg, var(--ink, #0A0A0A) 0%, var(--s900, #1C1917) 100%);
  color: #fff; border-radius: 14px; padding: 16px 22px;
  margin-bottom: 22px; display: flex; align-items: center; gap: 16px;
  box-shadow: var(--shadow-rest); position: relative; overflow: hidden;
}
.cm2-page .cm2-motivation::before {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(90deg, transparent 30%, rgba(196,18,48,.08) 50%, transparent 70%);
  background-size: 200% 100%; animation: cm2-shimmer 4s infinite;
  pointer-events: none;
}
.cm2-page .cm2-mot-icon {
  width: 44px; height: 44px; border-radius: 11px;
  background: linear-gradient(135deg, var(--red, #C41230) 0%, var(--red-dark, #A60F28) 100%);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; box-shadow: 0 4px 12px -3px rgba(196,18,48,.6);
  position: relative; z-index: 1;
}
.cm2-page .cm2-mot-mid { flex: 1; min-width: 0; position: relative; z-index: 1; }
.cm2-page .cm2-mot-eyebrow {
  font-size: 9.5px; font-weight: 800; letter-spacing: 0.22em;
  text-transform: uppercase; color: rgba(255,255,255,.55); margin-bottom: 3px;
}
.cm2-page .cm2-mot-line {
  font-size: 15px; font-weight: 800; color: #fff;
  letter-spacing: -0.015em; line-height: 1.3;
}
.cm2-page .cm2-mot-line b { color: #FCD34D; font-weight: 900; }
.cm2-page .cm2-mot-line .red { color: #FCA5A5; font-weight: 900; }
.cm2-page .cm2-mot-line .green { color: #86EFAC; font-weight: 900; }
.cm2-page .cm2-mot-stats { display: flex; gap: 18px; flex-shrink: 0; position: relative; z-index: 1; }
.cm2-page .cm2-mot-stat { display: flex; flex-direction: column; align-items: flex-end; gap: 2px; }
.cm2-page .cm2-mot-stat-k {
  font-size: 9.5px; font-weight: 800; letter-spacing: 0.18em;
  text-transform: uppercase; color: rgba(255,255,255,.45);
}
.cm2-page .cm2-mot-stat-v {
  font-size: 18px; font-weight: 900; color: #fff;
  font-variant-numeric: tabular-nums; letter-spacing: -0.025em; line-height: 1;
}
.cm2-page .cm2-mot-stat-v.rank { color: #FCD34D; }

/* ─── Role gating ───────────────────────────────────────────────────── */
.cm2-page [data-role-gate].cm2-locked,
.cm2-page .cm2-tab.cm2-locked {
  opacity: 0.4;
  cursor: not-allowed;
  position: relative;
}
.cm2-page .cm2-tab.cm2-locked::after {
  content: '🔒'; margin-left: 5px; font-size: 10px;
}
.cm2-page .cm2-tab.cm2-locked:hover {
  background: transparent !important;
  color: var(--s500, #78716C) !important;
}

/* ─── Team rollup section ──────────────────────────────────────────── */
.cm2-page .cm2-team-section { margin-top: 32px; }
.cm2-page .cm2-section-h {
  display: flex; align-items: flex-end; justify-content: space-between;
  gap: 14px; margin-bottom: 14px; padding-bottom: 12px;
  border-bottom: 1px solid var(--s200, #E7E5E4);
}
.cm2-page .cm2-section-h-eyebrow {
  font-size: 10.5px; font-weight: 800; letter-spacing: 0.22em;
  text-transform: uppercase; color: var(--red, #C41230);
  display: inline-flex; align-items: center; gap: 7px;
}
.cm2-page .cm2-section-h-title {
  font-size: 24px; font-weight: 900; letter-spacing: -0.025em;
  color: var(--ink, #0A0A0A); line-height: 1.1;
}
.cm2-page .cm2-section-h-sub {
  font-size: 12px; color: var(--s500, #78716C); font-weight: 600; margin-top: 4px;
}
.cm2-page .cm2-rollup {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 14px; margin-bottom: 16px;
}
@media (max-width: 1100px) { .cm2-page .cm2-rollup { grid-template-columns: repeat(2, 1fr); } }
.cm2-page .cm2-rollup-card {
  background: #fff; border: 1px solid var(--s200, #E7E5E4);
  border-radius: 14px; padding: 16px 18px;
  display: flex; flex-direction: column; gap: 6px;
  box-shadow: var(--shadow-rest); transition: all 180ms cubic-bezier(.4,0,.2,1);
}
.cm2-page .cm2-rollup-card:hover { transform: translateY(-1px); border-color: var(--s300, #D6D3D1); }
.cm2-page .cm2-rollup-card.accent-paid { border-left: 3px solid var(--cm2-ok-fg); }
.cm2-page .cm2-rollup-card.accent-due { border-left: 3px solid var(--cm2-due-fg); }
.cm2-page .cm2-rollup-card.accent-pending { border-left: 3px solid var(--cm2-pending-fg); }
.cm2-page .cm2-rollup-card.accent-total { border-left: 3px solid var(--ink, #0A0A0A); }
.cm2-page .cm2-rollup-k {
  font-size: 10px; font-weight: 800; letter-spacing: 0.2em;
  text-transform: uppercase; color: var(--s500, #78716C);
}
.cm2-page .cm2-rollup-v {
  font-size: 26px; font-weight: 900; color: var(--ink, #0A0A0A);
  letter-spacing: -0.035em; line-height: 1; font-variant-numeric: tabular-nums;
}
.cm2-page .cm2-rollup-sub { font-size: 11px; color: var(--s500, #78716C); font-weight: 600; }

/* ─── Pay Run banner ───────────────────────────────────────────────── */
.cm2-page .cm2-payrun-banner {
  background: linear-gradient(135deg, #fff 0%, var(--ok-bg, #DCFCE7) 100%);
  border: 1px solid rgba(21,128,61,.25); border-radius: 14px;
  padding: 16px 20px; margin-bottom: 16px;
  display: flex; align-items: center; gap: 16px;
  box-shadow: var(--shadow-rest); position: relative; overflow: hidden;
}
.cm2-page .cm2-payrun-banner::before {
  content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 4px;
  background: linear-gradient(180deg, var(--cm2-ok-fg) 0%, var(--cm2-ok-light) 100%);
}
.cm2-page .cm2-payrun-icon {
  width: 48px; height: 48px; border-radius: 12px;
  background: var(--cm2-ok-fg); color: #fff;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; font-size: 22px; font-weight: 900;
  box-shadow: 0 4px 12px -3px rgba(21,128,61,.5);
}
.cm2-page .cm2-payrun-mid { flex: 1; min-width: 0; }
.cm2-page .cm2-payrun-eyebrow {
  font-size: 10px; font-weight: 800; letter-spacing: 0.22em;
  text-transform: uppercase; color: var(--cm2-ok-fg); margin-bottom: 3px;
}
.cm2-page .cm2-payrun-title {
  font-size: 18px; font-weight: 900; color: var(--ink, #0A0A0A);
  letter-spacing: -0.02em; line-height: 1.2;
}
.cm2-page .cm2-payrun-title b { color: var(--cm2-ok-fg); }
.cm2-page .cm2-payrun-sub {
  font-size: 12.5px; color: var(--s700, #44403C);
  font-weight: 600; margin-top: 4px;
}
.cm2-page .cm2-payrun-r { display: flex; gap: 8px; flex-shrink: 0; }

/* ─── Targets management panel (used by Won Deals Phase 2) ─────────── */
.wd2-targets {
  margin-top: 32px; background: #fff;
  border: 1px solid var(--s200, #E7E5E4); border-radius: 14px;
  overflow: hidden; box-shadow: var(--shadow-rest);
}
.wd2-targets-h {
  padding: 14px 18px; border-bottom: 1px solid var(--s100, #F5F5F4);
  display: flex; align-items: center; justify-content: space-between;
  background: linear-gradient(180deg, var(--s50, #FAFAF9) 0%, #fff 100%);
}
.wd2-targets-title {
  font-size: 14px; font-weight: 800; color: var(--ink, #0A0A0A);
  letter-spacing: -0.015em;
}
.wd2-targets-sub {
  font-size: 11.5px; color: var(--s500, #78716C); font-weight: 600; margin-top: 2px;
}
.wd2-targets-table { width: 100%; border-collapse: collapse; }
.wd2-targets-table th {
  background: var(--s50, #FAFAF9); padding: 9px 14px;
  font-size: 9.5px; font-weight: 800; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--s500, #78716C);
  text-align: left; border-bottom: 1px solid var(--s200, #E7E5E4);
}
.wd2-targets-table th.r { text-align: right; }
.wd2-targets-table td {
  padding: 10px 14px; font-size: 12.5px;
  border-bottom: 1px solid var(--s100, #F5F5F4); vertical-align: middle;
}
.wd2-targets-table tr:last-child td { border-bottom: none; }
.wd2-targets-table tr:hover { background: var(--s50, #FAFAF9); }
.wd2-targets-rep {
  display: flex; align-items: center; gap: 9px;
  font-size: 12.5px; font-weight: 800; color: var(--ink, #0A0A0A);
}
.wd2-targets-rep .av {
  width: 28px; height: 28px; border-radius: 7px;
  color: #fff; font-size: 10.5px; font-weight: 800;
  display: flex; align-items: center; justify-content: center;
  letter-spacing: -0.02em; flex-shrink: 0;
}
.wd2-targets-input {
  padding: 5px 9px; font-size: 12px; font-weight: 700;
  border: 1px solid var(--s200, #E7E5E4); border-radius: 6px;
  background: #fff; font-family: inherit; width: 130px;
  text-align: right; font-variant-numeric: tabular-nums;
  color: var(--ink, #0A0A0A);
  transition: all 180ms cubic-bezier(.4,0,.2,1);
}
.wd2-targets-input:hover { border-color: var(--s300, #D6D3D1); }
.wd2-targets-input:focus {
  outline: none; border-color: var(--ink, #0A0A0A);
  box-shadow: 0 0 0 3px rgba(10,10,10,.05);
}
.wd2-targets-input.saved { border-color: var(--cm2-ok-fg); }
.wd2-targets-foot {
  padding: 11px 18px; background: var(--s50, #FAFAF9);
  border-top: 1px solid var(--s100, #F5F5F4);
  display: flex; align-items: center; justify-content: space-between;
  font-size: 10.5px; color: var(--s500, #78716C); font-weight: 700;
}
