/*
 * practice-os.css — Practice OS shared design contract
 * Agent 1 authors this. Agents 2 and 3 link it and build module pages against it.
 * Every .pos-* class and per-module accent token defined here.
 * Builds on cc-* tokens from reimburseos-design.css — never redefines them.
 * Last updated: 2026-05-16
 */

/* ═══════════════════════════════════════════════════════════════════
   1. ACCENT TOKEN REGISTRY
   Module pages set --mod-accent locally; these are the palette roots.
   ═══════════════════════════════════════════════════════════════════ */

:root {
  --accent-rate:       #00D4FF;  /* Rate Intelligence — cyan (system accent) */
  --accent-leverage:   #F5B800;  /* Leverage Memo + Leverage Contract — gold  */
  --accent-appeals:    #DC2F3D;  /* Appeals — red                             */
  --accent-recovery:   #F5B800;  /* Recovery — gold (shares leverage family)  */
  --accent-scrubber:   #10B981;  /* Scrubber — emerald                        */
  --accent-renewals:   #818CF8;  /* Renewals Calendar — indigo                */
  --accent-audit:      #00D4FF;  /* Practice Audit — system cyan              */

  /* Module page default — overridden per page via :root on each page */
  --mod-accent: var(--accent-rate);

  /* Shared layout tokens */
  --pos-topbar-h:   64px;
  --pos-tabbar-h:   56px;
  --pos-content-max: 1280px;
  --pos-card-radius: 14px;
  --pos-stream-bg:  #040810;
}

/* ═══════════════════════════════════════════════════════════════════
   2. TAB BAR — .pos-tabbar, .pos-tab, .pos-tab.is-active
   The horizontal module navigation rendered identically on every
   app page. Sits below the main topbar.
   ═══════════════════════════════════════════════════════════════════ */

.pos-tabbar {
  position: sticky;
  top: var(--pos-topbar-h);
  z-index: 80;
  background: rgba(0, 0, 0, 0.92);
  backdrop-filter: saturate(140%) blur(14px);
  -webkit-backdrop-filter: saturate(140%) blur(14px);
  border-bottom: 1px solid var(--cc-divider);
  display: flex;
  align-items: stretch;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  gap: 0;
  padding: 0 20px;
  min-height: var(--pos-tabbar-h);
}

.pos-tabbar::-webkit-scrollbar {
  display: none;
}

.pos-tab {
  /* tap-target: 44px min-height enforced via padding + line-height */
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 0 16px;
  min-height: 44px;
  border-bottom: 2px solid transparent;
  border-top: 2px solid transparent;
  font-family: var(--cc-font-body);
  font-size: 13px;
  font-weight: 500;
  color: var(--cc-fg-muted);
  text-decoration: none;
  white-space: nowrap;
  flex-shrink: 0;
  cursor: pointer;
  background: transparent;
  border-left: none;
  border-right: none;
  transition:
    color var(--cc-dur) var(--cc-ease),
    border-bottom-color var(--cc-dur) var(--cc-ease),
    background var(--cc-dur) var(--cc-ease);
  position: relative;
}

.pos-tab:hover {
  color: var(--cc-fg);
  background: rgba(255, 255, 255, 0.04);
}

.pos-tab:focus-visible {
  outline: 2px solid var(--mod-accent, var(--cc-accent));
  outline-offset: -2px;
  border-radius: 4px;
}

.pos-tab.is-active {
  color: var(--mod-accent, var(--cc-accent));
  border-bottom-color: var(--mod-accent, var(--cc-accent));
  font-weight: 600;
}

/* Badge chips (LIVE, BETA, PRO) on tab items */
.pos-tab .pos-tab-badge {
  display: inline-flex;
  align-items: center;
  font-family: var(--cc-font-mono);
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 2px 6px;
  border-radius: 999px;
  border: 1px solid currentColor;
  opacity: 0.75;
  line-height: 1;
}

.pos-tab .pos-tab-badge.live   { color: #10B981; }
.pos-tab .pos-tab-badge.beta   { color: var(--cc-fg-muted); }
.pos-tab .pos-tab-badge.pro    { color: #818CF8; }

/* Mobile: tighten tab padding */
@media (max-width: 768px) {
  .pos-tabbar { padding: 0 12px; }
  .pos-tab    { padding: 0 12px; font-size: 12px; }
  .pos-tab .pos-tab-badge { display: none; }
}

/* When topbar goes two-row on mobile, shift the sticky offset */
@media (max-width: 780px) {
  .pos-tabbar { top: var(--topbar-h, 104px); }
}

/* ═══════════════════════════════════════════════════════════════════
   3. MODULE SHELL — .pos-module, .pos-module__head, .pos-module__title,
      .pos-module__eyebrow
   ═══════════════════════════════════════════════════════════════════ */

.pos-module {
  max-width: var(--pos-content-max);
  margin: 0 auto;
  padding: 36px 28px 96px;
}

@media (max-width: 780px) {
  .pos-module { padding: 24px 16px 72px; }
}

.pos-module__head {
  margin-bottom: 28px;
}

.pos-module__eyebrow {
  font-family: var(--cc-font-mono);
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--mod-accent, var(--cc-accent));
  margin: 0 0 10px;
  display: flex;
  align-items: center;
  gap: 8px;
}

.pos-module__title {
  font-family: var(--cc-font-display);
  font-weight: 700;
  font-size: clamp(22px, 3vw, 30px);
  letter-spacing: -0.025em;
  line-height: 1.15;
  color: var(--cc-fg-bright);
  margin: 0 0 8px;
}

.pos-module__lede {
  font-family: var(--cc-font-body);
  font-size: 15px;
  line-height: 1.65;
  color: var(--cc-fg-muted);
  max-width: 700px;
  margin: 0;
}

/* ═══════════════════════════════════════════════════════════════════
   4. MODEBAR — .pos-modebar
   Beta / Practice Mode banner. Appears at top of every input form.
   ═══════════════════════════════════════════════════════════════════ */

.pos-modebar {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 14px 18px;
  background: rgba(245, 158, 11, 0.06);
  border: 1px solid rgba(245, 158, 11, 0.28);
  border-left: 3px solid var(--warn, #f59e0b);
  border-radius: 10px;
  margin-bottom: 24px;
  font-family: var(--cc-font-body);
  font-size: 13px;
  line-height: 1.6;
  color: var(--cc-fg-muted);
}

.pos-modebar__icon {
  font-size: 16px;
  flex-shrink: 0;
  margin-top: 1px;
  line-height: 1;
}

.pos-modebar__body { flex: 1; min-width: 0; }

.pos-modebar strong {
  color: var(--cc-fg);
  font-weight: 600;
}

/* ═══════════════════════════════════════════════════════════════════
   5. CARDS — .pos-card
   ═══════════════════════════════════════════════════════════════════ */

.pos-card {
  background: linear-gradient(180deg, var(--cc-bg-raised), rgba(13, 13, 15, 0.6));
  border: 1px solid var(--cc-border-strong);
  border-radius: var(--pos-card-radius);
  padding: 22px;
  position: relative;
  overflow: hidden;
}

.pos-card--accent {
  border-color: var(--mod-accent, var(--cc-accent));
  background: linear-gradient(
    135deg,
    rgba(var(--pos-accent-rgb, 0, 212, 255), 0.07) 0%,
    rgba(var(--pos-accent-rgb, 0, 212, 255), 0.02) 100%
  );
}

/* ═══════════════════════════════════════════════════════════════════
   6. STAT TILES — .pos-stat, .pos-stat__num, .pos-stat__lbl
   ═══════════════════════════════════════════════════════════════════ */

.pos-stat {
  background: var(--cc-bg-card);
  border: 1px solid var(--cc-border);
  border-radius: 12px;
  padding: 16px 18px;
}

.pos-stat__lbl {
  font-family: var(--cc-font-mono);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--cc-fg-faint);
  margin-bottom: 6px;
}

.pos-stat__num {
  font-family: var(--cc-font-mono);
  font-weight: 700;
  font-size: 26px;
  letter-spacing: -0.03em;
  color: var(--cc-fg-bright);
  line-height: 1.05;
}

.pos-stat__num.accent {
  color: var(--mod-accent, var(--cc-accent));
}

.pos-stat__sub {
  font-family: var(--cc-font-mono);
  font-size: 11px;
  color: var(--cc-fg-faint);
  margin-top: 4px;
  letter-spacing: 0.04em;
}

/* ═══════════════════════════════════════════════════════════════════
   7. BUTTONS — .pos-btn, .pos-btn--primary, .pos-btn--ghost
   All tap targets >= 44px.
   ═══════════════════════════════════════════════════════════════════ */

.pos-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 44px;
  padding: 11px 22px;
  border-radius: 10px;
  border: 1px solid var(--cc-border-strong);
  font-family: var(--cc-font-body);
  font-weight: 600;
  font-size: 14px;
  cursor: pointer;
  background: var(--cc-bg-raised);
  color: var(--cc-fg);
  text-decoration: none;
  white-space: nowrap;
  transition:
    background var(--cc-dur) var(--cc-ease),
    border-color var(--cc-dur) var(--cc-ease),
    transform var(--cc-dur) var(--cc-ease),
    box-shadow var(--cc-dur) var(--cc-ease);
}

.pos-btn:hover {
  background: var(--cc-bg-card);
  border-color: var(--mod-accent, var(--cc-accent));
  transform: translateY(-1px);
}

.pos-btn:focus-visible {
  outline: 2px solid var(--mod-accent, var(--cc-accent));
  outline-offset: 2px;
  border-radius: 10px;
}

.pos-btn:disabled,
.pos-btn[aria-disabled="true"] {
  opacity: 0.45;
  cursor: not-allowed;
  transform: none;
}

.pos-btn--primary {
  background: var(--mod-accent, var(--cc-accent));
  color: #04121a;
  border-color: transparent;
  box-shadow:
    0 0 0 1px var(--mod-accent, var(--cc-accent)),
    0 0 18px rgba(0, 212, 255, 0.3);
}

/* Specificity fix: .cc-scope a (0,1,1) beats .pos-btn--primary (0,1,0).
   Force dark ink at (0,2,0) so primary buttons are always readable. */
.cc-scope .pos-btn--primary,
.cc-scope a.pos-btn--primary,
.cc-scope button.pos-btn--primary { color: #04121a !important; }

.pos-btn--primary:hover {
  filter: brightness(1.08);
  transform: translateY(-1px);
  background: var(--mod-accent, var(--cc-accent));
  border-color: transparent;
}

.cc-scope .pos-btn--primary:hover,
.cc-scope a.pos-btn--primary:hover,
.cc-scope button.pos-btn--primary:hover { color: #04121a !important; }

.pos-btn--ghost {
  background: transparent;
  border: 1px solid var(--cc-border-strong);
  color: var(--cc-fg-muted);
}

.pos-btn--ghost:hover {
  border-color: var(--cc-fg-muted);
  color: var(--cc-fg);
  background: rgba(255, 255, 255, 0.04);
}

/* Small variant */
.pos-btn--sm {
  min-height: 36px;
  padding: 7px 16px;
  font-size: 13px;
}

/* ═══════════════════════════════════════════════════════════════════
   8. FORM INPUTS — .pos-input, .pos-textarea, .pos-dropzone
   font-size 16px on mobile prevents iOS auto-zoom.
   ═══════════════════════════════════════════════════════════════════ */

.pos-input,
.pos-textarea {
  width: 100%;
  background: var(--cc-bg-card);
  border: 1px solid var(--cc-border-strong);
  border-radius: 10px;
  padding: 11px 14px;
  color: var(--cc-fg);
  font-family: var(--cc-font-body);
  font-size: 14px;
  line-height: 1.5;
  outline: none;
  transition: border-color var(--cc-dur) var(--cc-ease), box-shadow var(--cc-dur) var(--cc-ease);
  min-height: 44px;
}

/* iOS auto-zoom guard */
@media (max-width: 768px) {
  .pos-input,
  .pos-textarea { font-size: 16px; }
}

.pos-input:focus,
.pos-textarea:focus {
  border-color: var(--mod-accent, var(--cc-accent));
  box-shadow: 0 0 0 2px rgba(0, 212, 255, 0.12);
}

.pos-input::placeholder,
.pos-textarea::placeholder { color: var(--cc-fg-faint); }

.pos-textarea {
  min-height: 140px;
  resize: vertical;
}

/* File drop zone */
.pos-dropzone {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 12px;
  min-height: 140px;
  padding: 28px 20px;
  background: var(--cc-bg-raised);
  border: 2px dashed var(--cc-border-strong);
  border-radius: var(--pos-card-radius);
  cursor: pointer;
  transition:
    border-color var(--cc-dur) var(--cc-ease),
    background var(--cc-dur) var(--cc-ease);
  text-align: center;
}

.pos-dropzone:hover,
.pos-dropzone.drag-over {
  border-color: var(--mod-accent, var(--cc-accent));
  background: rgba(0, 212, 255, 0.04);
}

.pos-dropzone__icon {
  font-size: 28px;
  line-height: 1;
  color: var(--cc-fg-faint);
}

.pos-dropzone__label {
  font-family: var(--cc-font-body);
  font-size: 14px;
  color: var(--cc-fg-muted);
  line-height: 1.5;
}

.pos-dropzone__sub {
  font-family: var(--cc-font-mono);
  font-size: 11px;
  letter-spacing: 0.06em;
  color: var(--cc-fg-faint);
}

/* ═══════════════════════════════════════════════════════════════════
   9. STREAMING OUTPUT — .pos-stream
   Terminal-style area for Claude streaming output.
   ═══════════════════════════════════════════════════════════════════ */

.pos-stream {
  background: var(--pos-stream-bg);
  border: 1px solid rgba(0, 212, 255, 0.14);
  border-radius: var(--pos-card-radius);
  overflow: hidden;
  box-shadow: 0 0 0 1px rgba(0, 212, 255, 0.06), 0 8px 40px rgba(0, 0, 0, 0.5);
}

.pos-stream__bar {
  background: rgba(0, 212, 255, 0.05);
  border-bottom: 1px solid rgba(0, 212, 255, 0.10);
  padding: 10px 16px;
  display: flex;
  align-items: center;
  gap: 10px;
}

.pos-stream__dots {
  display: flex;
  gap: 6px;
  flex-shrink: 0;
}

.pos-stream__dots span {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  display: block;
}

.pos-stream__dots span:nth-child(1) { background: #ff5f56; }
.pos-stream__dots span:nth-child(2) { background: #ffbd2e; }
.pos-stream__dots span:nth-child(3) { background: #27c93f; }

.pos-stream__title {
  font-family: var(--cc-font-mono);
  font-size: 11px;
  color: var(--cc-fg-faint);
  letter-spacing: 0.08em;
  flex: 1;
  text-align: center;
}

.pos-stream__live {
  font-family: var(--cc-font-mono);
  font-size: 10px;
  letter-spacing: 0.10em;
  color: var(--mod-accent, var(--cc-accent));
  display: flex;
  align-items: center;
  gap: 5px;
}

.pos-stream__live::before {
  content: '';
  display: block;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: currentColor;
  box-shadow: 0 0 8px currentColor;
  animation: pos-live-blink 0.9s ease-in-out infinite;
}

@keyframes pos-live-blink {
  0%, 100% { opacity: 1; }
  50%       { opacity: 0.3; }
}

.pos-stream__body {
  padding: 18px 20px;
  min-height: 220px;
  max-height: 340px;
  overflow-y: auto;
  font-family: var(--cc-font-mono);
  font-size: 12.5px;
  line-height: 1.7;
  color: var(--cc-fg-muted);
}

.pos-stream__body::-webkit-scrollbar { width: 4px; }
.pos-stream__body::-webkit-scrollbar-thumb {
  background: rgba(255, 255, 255, 0.1);
  border-radius: 2px;
}

.pos-stream__line         { margin: 0; padding: 0; }
.pos-stream__line.prompt  { color: var(--mod-accent, var(--cc-accent)); }
.pos-stream__line.system  { color: rgba(0, 212, 255, 0.45); font-size: 11px; }
.pos-stream__line.data    { color: var(--cc-fg-bright); }
.pos-stream__line.draft   { color: #a3f7b5; }
.pos-stream__line.warn    { color: var(--warn, #f59e0b); }

.pos-stream__cursor {
  display: inline-block;
  width: 2px;
  height: 14px;
  background: var(--mod-accent, var(--cc-accent));
  margin-left: 2px;
  vertical-align: middle;
  animation: pos-cursor-blink 0.6s step-end infinite;
}

@keyframes pos-cursor-blink {
  0%, 100% { opacity: 1; }
  50%       { opacity: 0; }
}

/* ═══════════════════════════════════════════════════════════════════
   10. TABLES — .pos-table, .pos-table__row
   ═══════════════════════════════════════════════════════════════════ */

.pos-table {
  background: var(--cc-bg-raised);
  border: 1px solid var(--cc-border);
  border-radius: var(--pos-card-radius);
  overflow: hidden;
}

.pos-table__head {
  display: grid;
  gap: 12px;
  padding: 10px 18px;
  background: var(--cc-bg-card);
  border-bottom: 1px solid var(--cc-border-strong);
  font-family: var(--cc-font-mono);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--cc-fg-faint);
}

.pos-table__row {
  display: grid;
  gap: 12px;
  padding: 13px 18px;
  border-bottom: 1px solid var(--cc-border);
  align-items: center;
  font-size: 13.5px;
  transition: background var(--cc-dur-fast) var(--cc-ease);
}

.pos-table__row:last-child { border-bottom: none; }

.pos-table__row:hover {
  background: var(--cc-bg-card);
}

.pos-table__row--accent {
  border-left: 3px solid var(--mod-accent, var(--cc-accent));
  background: rgba(0, 212, 255, 0.03);
}

.pos-table__row--warn {
  border-left: 3px solid var(--warn, #f59e0b);
  background: rgba(245, 158, 11, 0.03);
}

/* ═══════════════════════════════════════════════════════════════════
   11. FLAGS — .pos-flag, .pos-flag--blocking, --warning, --info
   Severity-tagged audit flags (Scrubber, Appeals).
   ═══════════════════════════════════════════════════════════════════ */

.pos-flag {
  padding: 12px 16px;
  border-radius: 10px;
  border: 1px solid;
  display: flex;
  gap: 12px;
  align-items: flex-start;
  font-family: var(--cc-font-body);
  font-size: 13px;
  line-height: 1.6;
}

.pos-flag + .pos-flag { margin-top: 8px; }

.pos-flag__icon {
  font-size: 16px;
  flex-shrink: 0;
  line-height: 1.3;
}

.pos-flag__body { flex: 1; min-width: 0; }

.pos-flag__rule {
  font-family: var(--cc-font-mono);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  margin-bottom: 4px;
}

.pos-flag__text { color: var(--cc-fg-muted); }

.pos-flag__citation {
  font-family: var(--cc-font-mono);
  font-size: 10.5px;
  color: var(--cc-fg-faint);
  margin-top: 4px;
}

.pos-flag--blocking {
  background: rgba(220, 47, 61, 0.07);
  border-color: rgba(220, 47, 61, 0.35);
  color: var(--cc-fg);
}
.pos-flag--blocking .pos-flag__rule { color: #DC2F3D; }

.pos-flag--warning {
  background: rgba(245, 158, 11, 0.07);
  border-color: rgba(245, 158, 11, 0.35);
  color: var(--cc-fg);
}
.pos-flag--warning .pos-flag__rule { color: #f59e0b; }

.pos-flag--info {
  background: rgba(0, 212, 255, 0.05);
  border-color: rgba(0, 212, 255, 0.25);
  color: var(--cc-fg);
}
.pos-flag--info .pos-flag__rule { color: var(--cc-accent); }

/* ═══════════════════════════════════════════════════════════════════
   12. FAMILY LADDER — .pos-ladder, .pos-ladder__step, .is-current
   Dashboard overview: shows where the customer sits in the
   Snapshot -> Leverage Memo -> Practice Audit -> Pro journey.
   ═══════════════════════════════════════════════════════════════════ */

.pos-ladder {
  display: flex;
  flex-direction: column;
  gap: 0;
  border: 1px solid var(--cc-border);
  border-radius: var(--pos-card-radius);
  overflow: hidden;
  background: var(--cc-bg-raised);
}

.pos-ladder__step {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 16px 20px;
  border-bottom: 1px solid var(--cc-border);
  position: relative;
  text-decoration: none;
  color: var(--cc-fg-muted);
  transition: background var(--cc-dur-fast) var(--cc-ease);
}

.pos-ladder__step:last-child { border-bottom: none; }

.pos-ladder__step:hover {
  background: var(--cc-bg-card);
  color: var(--cc-fg);
}

.pos-ladder__step.is-current {
  background: linear-gradient(
    135deg,
    rgba(0, 212, 255, 0.08) 0%,
    rgba(0, 212, 255, 0.02) 100%
  );
  border-left: 3px solid var(--mod-accent, var(--cc-accent));
  padding-left: 17px;
  color: var(--cc-fg);
}

.pos-ladder__step.is-done {
  opacity: 0.7;
}

.pos-ladder__step.is-locked {
  opacity: 0.45;
  pointer-events: none;
}

.pos-ladder__dot {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  border: 2px solid var(--cc-border-strong);
  background: var(--cc-bg-card);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  flex-shrink: 0;
  position: relative;
  z-index: 1;
}

.pos-ladder__step.is-current .pos-ladder__dot {
  border-color: var(--mod-accent, var(--cc-accent));
  background: rgba(0, 212, 255, 0.12);
  box-shadow: 0 0 0 3px rgba(0, 212, 255, 0.10);
}

.pos-ladder__step.is-done .pos-ladder__dot {
  border-color: #10B981;
  background: rgba(16, 185, 129, 0.12);
  color: #10B981;
}

.pos-ladder__body { flex: 1; min-width: 0; }

.pos-ladder__label {
  font-family: var(--cc-font-body);
  font-weight: 600;
  font-size: 14px;
  color: var(--cc-fg);
  line-height: 1.25;
  letter-spacing: -0.01em;
}

.pos-ladder__step.is-current .pos-ladder__label {
  color: var(--mod-accent, var(--cc-accent));
}

.pos-ladder__desc {
  font-family: var(--cc-font-mono);
  font-size: 11px;
  color: var(--cc-fg-faint);
  letter-spacing: 0.04em;
  margin-top: 2px;
  line-height: 1.4;
}

.pos-ladder__cta {
  font-family: var(--cc-font-mono);
  font-size: 11px;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--mod-accent, var(--cc-accent));
  font-weight: 600;
  white-space: nowrap;
  flex-shrink: 0;
}

/* Connector line between steps */
.pos-ladder__step::before {
  content: '';
  position: absolute;
  left: 36px;
  bottom: -1px;
  width: 1px;
  height: calc(100% - 32px - 16px - 8px);
  background: var(--cc-border);
  top: calc(16px + 32px);
  pointer-events: none;
}

.pos-ladder__step:last-child::before { display: none; }

/* ═══════════════════════════════════════════════════════════════════
   13. STATUS PILLS — .pos-status
   Appeal / recovery workflow state indicators.
   ═══════════════════════════════════════════════════════════════════ */

.pos-status {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-family: var(--cc-font-mono);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding: 3px 10px;
  border-radius: 999px;
  border: 1px solid;
  white-space: nowrap;
  line-height: 1;
}

.pos-status--drafted {
  color: var(--cc-fg-muted);
  border-color: var(--cc-border-strong);
  background: rgba(255, 255, 255, 0.04);
}

.pos-status--sent {
  color: #818CF8;
  border-color: rgba(129, 140, 248, 0.40);
  background: rgba(129, 140, 248, 0.08);
}

.pos-status--pending {
  color: #f59e0b;
  border-color: rgba(245, 158, 11, 0.40);
  background: rgba(245, 158, 11, 0.07);
}

.pos-status--won {
  color: #10B981;
  border-color: rgba(16, 185, 129, 0.40);
  background: rgba(16, 185, 129, 0.07);
}

.pos-status--lost {
  color: #DC2F3D;
  border-color: rgba(220, 47, 61, 0.40);
  background: rgba(220, 47, 61, 0.07);
}

/* ═══════════════════════════════════════════════════════════════════
   14. SECTION HEADER helpers used inside module content
   ═══════════════════════════════════════════════════════════════════ */

.pos-section-h {
  font-family: var(--cc-font-mono);
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--mod-accent, var(--cc-accent));
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-bottom: 1px solid var(--cc-divider);
  padding-bottom: 10px;
  margin: 32px 0 16px;
}

.pos-section-h__action {
  font-family: var(--cc-font-mono);
  font-size: 10px;
  color: var(--cc-fg-faint);
  text-transform: none;
  letter-spacing: 0.04em;
  font-weight: 400;
  cursor: pointer;
  background: none;
  border: none;
  padding: 0;
}

.pos-section-h__action:hover { color: var(--mod-accent, var(--cc-accent)); }

/* ═══════════════════════════════════════════════════════════════════
   15. LABEL / FORM HELPERS
   ═══════════════════════════════════════════════════════════════════ */

.pos-label {
  display: block;
  font-family: var(--cc-font-mono);
  font-size: 10.5px;
  font-weight: 600;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--cc-fg-faint);
  margin-bottom: 6px;
}

.pos-field { margin-bottom: 18px; }

.pos-field-help {
  font-family: var(--cc-font-mono);
  font-size: 10.5px;
  color: var(--cc-fg-faint);
  letter-spacing: 0.04em;
  margin-top: 5px;
  line-height: 1.5;
}

/* Grid helpers */
.pos-row-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

.pos-row-3 {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr;
  gap: 12px;
}

@media (max-width: 600px) {
  .pos-row-2,
  .pos-row-3 { grid-template-columns: 1fr; }
}

/* ═══════════════════════════════════════════════════════════════════
   16. UPGRADE / UPSELL BLOCK
   ═══════════════════════════════════════════════════════════════════ */

.pos-upgrade {
  background: linear-gradient(135deg, rgba(245, 158, 11, 0.07), rgba(245, 158, 11, 0.02));
  border: 1px solid rgba(245, 158, 11, 0.40);
  border-radius: var(--pos-card-radius);
  padding: 24px;
  display: flex;
  align-items: center;
  gap: 20px;
  flex-wrap: wrap;
}

.pos-upgrade__body {
  flex: 1;
  min-width: 260px;
}

.pos-upgrade__eyebrow {
  font-family: var(--cc-font-mono);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--warn, #f59e0b);
  margin-bottom: 6px;
}

.pos-upgrade__title {
  font-family: var(--cc-font-display);
  font-weight: 700;
  font-size: 18px;
  color: var(--cc-fg-bright);
  letter-spacing: -0.01em;
  margin-bottom: 8px;
}

.pos-upgrade__text {
  font-family: var(--cc-font-body);
  font-size: 13.5px;
  color: var(--cc-fg-muted);
  line-height: 1.6;
  margin: 0;
}

/* ═══════════════════════════════════════════════════════════════════
   17. BADGE / TAG HELPERS
   ═══════════════════════════════════════════════════════════════════ */

.pos-badge {
  display: inline-flex;
  align-items: center;
  font-family: var(--cc-font-mono);
  font-size: 9.5px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding: 3px 9px;
  border-radius: 999px;
  border: 1px solid currentColor;
  line-height: 1;
  white-space: nowrap;
}

.pos-badge--beta   { color: var(--cc-fg-muted);  background: rgba(255,255,255,0.04); }
.pos-badge--live   { color: #10B981;              background: rgba(16,185,129,0.08);  }
.pos-badge--pro    { color: #818CF8;              background: rgba(129,140,248,0.08); }
.pos-badge--gold   { color: #F5B800;              background: rgba(245,184,0,0.08);   }
.pos-badge--new    { color: var(--cc-accent);     background: rgba(0,212,255,0.08);   }

/* ═══════════════════════════════════════════════════════════════════
   18. EMPTY STATE
   ═══════════════════════════════════════════════════════════════════ */

.pos-empty {
  padding: 56px 20px;
  text-align: center;
  background: var(--cc-bg-raised);
  border: 1px dashed var(--cc-border-strong);
  border-radius: var(--pos-card-radius);
  color: var(--cc-fg-faint);
  font-family: var(--cc-font-mono);
}

.pos-empty__icon  { font-size: 32px; margin-bottom: 12px; line-height: 1; opacity: 0.6; }
.pos-empty__title { font-family: var(--cc-font-display); font-size: 17px; color: var(--cc-fg-muted); font-weight: 700; margin-bottom: 8px; }
.pos-empty__body  { font-size: 13px; line-height: 1.6; max-width: 420px; margin: 0 auto 18px; }

/* ═══════════════════════════════════════════════════════════════════
   19. TOAST NOTIFICATION
   ═══════════════════════════════════════════════════════════════════ */

.pos-toast {
  position: fixed;
  top: 24px;
  left: 50%;
  transform: translate(-50%, -140%);
  background: var(--cc-bg-card);
  border: 1px solid var(--cc-border-strong);
  border-radius: 999px;
  padding: 12px 22px;
  font-family: var(--cc-font-body);
  font-size: 14px;
  font-weight: 600;
  color: var(--cc-fg);
  box-shadow: 0 20px 60px rgba(0,0,0,0.6);
  z-index: 500;
  display: flex;
  align-items: center;
  gap: 10px;
  white-space: nowrap;
  transition: transform 0.5s cubic-bezier(0.2, 0.7, 0.3, 1.2);
  pointer-events: none;
}

.pos-toast.show { transform: translate(-50%, 0); }

.pos-toast--ok  { background: linear-gradient(135deg, #059669, #10B981); color: #0a0f1c; }
.pos-toast--err { background: linear-gradient(135deg, #B91C1C, #DC2F3D); color: #fff;    }

@media (max-width: 480px) {
  .pos-toast {
    left: 12px; right: 12px;
    transform: translateY(-140%);
    white-space: normal;
    border-radius: 14px;
  }
  .pos-toast.show { transform: translateY(0); }
}

/* ═══════════════════════════════════════════════════════════════════
   20. REDUCED MOTION — blanket override
   ═══════════════════════════════════════════════════════════════════ */

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }

  .pos-stream__live::before,
  .pos-stream__cursor { animation: none !important; }
}
