/* ============================================================================
   Paragon Lead Vetting — Console mockup
   Brand system extended from the Paragon Studio website (styleguide.html).
   Luxury-editorial: bronze on off-white, sharp edges, Optima/FreightNeo/Cabin.
   STATIC MOCKUP — no backend. Sample data only.
   ============================================================================ */

@font-face {
  font-family: 'Optima';
  src: url('fonts/optima-medium.ttf') format('truetype');
  font-weight: 500; font-display: swap;
}
@font-face {
  font-family: 'FreightNeo';
  src: url('fonts/freightneo-medium.ttf') format('truetype');
  font-weight: 500; font-display: swap;
}
@font-face {
  font-family: 'Cabin';
  src: url('fonts/cabin-regular.ttf') format('truetype');
  font-weight: 400; font-display: swap;
}
@font-face {
  font-family: 'Cabin';
  src: url('fonts/cabin-medium.ttf') format('truetype');
  font-weight: 500; font-display: swap;
}

:root {
  /* Brand colour (from styleguide.html) */
  --bronze:        #af987b;
  --bronze-dark:   #8a7760;
  --bronze-light:  #c4b49d;
  --bronze-10:     rgba(175, 152, 123, 0.10);
  --bronze-20:     rgba(175, 152, 123, 0.20);
  --charcoal:      #333333;
  --charcoal-dark: #1a1a1a;
  --charcoal-lt:   #4a4a4a;
  --offwhite:      #f2f2f2;
  --paper:         #f6f4f0;   /* warm canvas tint */
  --white:         #ffffff;
  --grey-200:      #f2f2f2;
  --grey-300:      #e0e0e0;
  --grey-400:      #bdbdbd;
  --grey-500:      #9e9e9e;
  --grey-600:      #757575;
  --grey-700:      #616161;

  /* Decision semantics (muted, brand-aligned) */
  --approve:   #5a7a5a;
  --approve-bg:rgba(90, 122, 90, 0.10);
  --reject:    #a04040;
  --reject-bg: rgba(160, 64, 64, 0.10);
  --nondesign: #5a6f7a;
  --nondesign-bg: rgba(90, 111, 122, 0.10);
  --followup:  #c4973d;
  --followup-bg: rgba(196, 151, 61, 0.12);
  --spam:      #757575;
  --spam-bg:   rgba(117, 117, 117, 0.10);

  /* Type */
  --font-heading: 'Optima', 'Palatino Linotype', 'Book Antiqua', serif;
  --font-body:    'FreightNeo', 'Georgia', 'Times New Roman', serif;
  --font-ui:      'Cabin', 'Helvetica Neue', Arial, sans-serif;
  --font-mono:    'SF Mono', 'Cascadia Mono', 'Consolas', monospace;

  --ease: cubic-bezier(0.16, 1, 0.3, 1);
  --shadow: 0 1px 2px rgba(26,26,26,0.04), 0 8px 24px -12px rgba(26,26,26,0.12);
  --shadow-lg: 0 2px 4px rgba(26,26,26,0.05), 0 24px 48px -20px rgba(26,26,26,0.18);
}

* { box-sizing: border-box; margin: 0; padding: 0; }

html { -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility; }

body {
  font-family: var(--font-body);
  color: var(--charcoal);
  background: var(--paper);
  font-size: 16px;
  line-height: 1.6;
}

a { color: inherit; text-decoration: none; }

/* ---- Eyebrow / labels ---- */
.eyebrow {
  font-family: var(--font-ui);
  font-size: 0.6875rem;
  font-weight: 500;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--bronze-dark);
}
.label {
  font-family: var(--font-ui);
  font-size: 0.6875rem;
  font-weight: 500;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--grey-600);
}

h1, h2, h3 { font-family: var(--font-heading); font-weight: 500; color: var(--charcoal-dark); letter-spacing: 0.01em; }
h1 { font-size: 2.25rem; line-height: 1.1; }
h2 { font-size: 1.5rem; line-height: 1.15; }
h3 { font-size: 1.125rem; }

/* ============================================================================
   App shell
   ============================================================================ */
.app { display: grid; grid-template-columns: 248px 1fr; min-height: 100vh; }

/* ---- Sidebar ---- */
.sidebar {
  background: var(--white);
  border-right: 1px solid var(--grey-300);
  display: flex; flex-direction: column;
  position: sticky; top: 0; height: 100vh;
}
.sidebar__brand {
  padding: 30px 28px 26px;
  background: var(--charcoal-dark);
}
.sidebar__brand img { height: 46px; width: auto; display: block; }
.sidebar__tag {
  margin-top: 16px;
  font-family: var(--font-ui);
  font-size: 0.625rem; letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--bronze-light);
}
.nav { padding: 20px 16px; flex: 1; }
.nav__group { margin-bottom: 28px; }
.nav__heading {
  font-family: var(--font-ui); font-size: 0.625rem; font-weight: 500;
  letter-spacing: 0.2em; text-transform: uppercase; color: var(--grey-500);
  padding: 0 12px 10px;
}
.nav__item {
  display: flex; align-items: center; gap: 12px;
  padding: 11px 12px; margin-bottom: 2px;
  font-family: var(--font-ui); font-size: 0.875rem; letter-spacing: 0.02em;
  color: var(--charcoal-lt);
  border-left: 2px solid transparent;
  transition: all 240ms var(--ease);
}
.nav__item:hover { background: var(--bronze-10); color: var(--charcoal-dark); }
.nav__item.is-active {
  background: var(--bronze-10); color: var(--charcoal-dark);
  border-left-color: var(--bronze); font-weight: 500;
}
.nav__item svg { width: 17px; height: 17px; stroke: currentColor; fill: none; stroke-width: 1.5; }
.nav__count {
  margin-left: auto; font-size: 0.75rem; color: var(--bronze-dark);
  background: var(--bronze-10); padding: 2px 8px; border-radius: 2px;
}
.sidebar__foot {
  padding: 18px 28px; border-top: 1px solid var(--grey-300);
  font-family: var(--font-ui); font-size: 0.75rem; color: var(--grey-600);
  display: flex; align-items: center; gap: 10px;
}
.avatar {
  width: 30px; height: 30px; border-radius: 50%;
  background: var(--charcoal-dark); color: var(--bronze-light);
  display: grid; place-items: center;
  font-family: var(--font-ui); font-size: 0.75rem; letter-spacing: 0.05em;
}

/* ---- Main ---- */
.main { display: flex; flex-direction: column; min-width: 0; }
.topbar {
  display: flex; align-items: center; gap: 20px;
  padding: 22px 40px; background: var(--paper);
  border-bottom: 1px solid var(--grey-300);
  position: sticky; top: 0; z-index: 10;
}
.topbar .eyebrow { display: block; margin-bottom: 4px; }
.topbar h1 { font-size: 1.75rem; }
.topbar__spacer { flex: 1; }

.phase-badge {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-ui); font-size: 0.6875rem; font-weight: 500;
  letter-spacing: 0.15em; text-transform: uppercase;
  color: var(--bronze-dark); background: var(--bronze-10);
  border: 1px solid var(--bronze-20);
  padding: 8px 14px;
}
.phase-badge .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--bronze); animation: pulse 2.4s var(--ease) infinite; }
@keyframes pulse { 0%,100%{opacity:1} 50%{opacity:0.4} }

.content { padding: 36px 40px 64px; max-width: 1280px; }

/* ============================================================================
   Buttons
   ============================================================================ */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 9px;
  padding: 14px 32px;
  font-family: var(--font-ui); font-size: 0.8125rem; font-weight: 500;
  letter-spacing: 0.15em; text-transform: uppercase; line-height: 1.4;
  border: 1.5px solid var(--charcoal-dark); border-radius: 0;
  background: var(--charcoal-dark); color: var(--white);
  cursor: pointer; transition: all 300ms var(--ease);
}
.btn:hover { background: transparent; color: var(--charcoal-dark); }
.btn--ghost { background: transparent; color: var(--charcoal-dark); }
.btn--ghost:hover { background: var(--charcoal-dark); color: var(--white); }
.btn--bronze { background: var(--bronze-dark); border-color: var(--bronze-dark); }
.btn--bronze:hover { background: transparent; color: var(--bronze-dark); }
.btn--sm { padding: 9px 18px; font-size: 0.6875rem; }
.btn__arrow { transition: transform 300ms var(--ease); }
.btn:hover .btn__arrow { transform: translateX(4px); }

/* ============================================================================
   Cards / surfaces
   ============================================================================ */
.card {
  background: var(--white); border: 1px solid var(--grey-300);
  box-shadow: var(--shadow);
}
.card--pad { padding: 28px 30px; }
.section-rule {
  display: flex; align-items: baseline; gap: 16px; margin-bottom: 20px;
}
.section-rule::after { content: ''; flex: 1; height: 1px; background: var(--grey-300); }

/* ============================================================================
   KPI strip
   ============================================================================ */
.kpis { display: grid; grid-template-columns: repeat(auto-fit, minmax(170px, 1fr)); gap: 1px; background: var(--grey-300); border: 1px solid var(--grey-300); margin-bottom: 32px; }
.kpi { background: var(--white); padding: 22px 24px; }
.kpi__val { font-family: var(--font-heading); font-size: 2rem; color: var(--charcoal-dark); line-height: 1; }
.kpi__val small { font-size: 1rem; color: var(--grey-500); }
.kpi__lab { margin-top: 8px; }
.kpi__delta { font-family: var(--font-ui); font-size: 0.75rem; margin-top: 6px; }
.kpi__delta.up { color: var(--approve); }
.kpi__delta.down { color: var(--reject); }

/* ============================================================================
   Filter bar
   ============================================================================ */
.filters { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; margin-bottom: 22px; }
.search {
  display: flex; align-items: center; gap: 10px; flex: 1; min-width: 240px;
  background: var(--white); border: 1px solid var(--grey-300); padding: 11px 16px;
}
.search input { border: none; outline: none; flex: 1; font-family: var(--font-ui); font-size: 0.875rem; background: transparent; color: var(--charcoal); }
.search svg { width: 16px; height: 16px; stroke: var(--grey-500); fill: none; stroke-width: 1.5; }
.chips { display: flex; gap: 6px; }
.chip {
  font-family: var(--font-ui); font-size: 0.6875rem; font-weight: 500;
  letter-spacing: 0.1em; text-transform: uppercase;
  padding: 9px 14px; border: 1px solid var(--grey-300); background: var(--white);
  color: var(--grey-600); cursor: pointer; transition: all 240ms var(--ease);
}
.chip:hover { border-color: var(--bronze); color: var(--charcoal-dark); }
.chip.is-active { background: var(--charcoal-dark); border-color: var(--charcoal-dark); color: var(--white); }

/* ============================================================================
   Decision badges
   ============================================================================ */
.badge {
  display: inline-flex; align-items: center; gap: 7px;
  font-family: var(--font-ui); font-size: 0.6875rem; font-weight: 500;
  letter-spacing: 0.1em; text-transform: uppercase;
  padding: 5px 11px; border-radius: 2px; white-space: nowrap;
}
.badge .tick { width: 6px; height: 6px; border-radius: 50%; background: currentColor; }
.badge--approve   { color: var(--approve);   background: var(--approve-bg); }
.badge--reject    { color: var(--reject);    background: var(--reject-bg); }
.badge--non_design{ color: var(--nondesign); background: var(--nondesign-bg); }
.badge--follow_up { color: var(--followup);  background: var(--followup-bg); }
.badge--spam      { color: var(--spam);      background: var(--spam-bg); }

.stage-tag { font-family: var(--font-mono); font-size: 0.6875rem; color: var(--grey-600); letter-spacing: 0.02em; }

/* ============================================================================
   Confidence meter
   ============================================================================ */
.conf { display: flex; align-items: center; gap: 10px; }
.conf__track { width: 64px; height: 4px; background: var(--grey-300); position: relative; overflow: hidden; }
.conf__fill { position: absolute; inset: 0 auto 0 0; background: var(--bronze); transform-origin: left; animation: grow 900ms var(--ease) both; }
@keyframes grow { from { transform: scaleX(0); } }
.conf__num { font-family: var(--font-ui); font-size: 0.8125rem; color: var(--charcoal); min-width: 34px; }

/* ============================================================================
   Queue table
   ============================================================================ */
.qtable { width: 100%; border-collapse: collapse; background: var(--white); border: 1px solid var(--grey-300); box-shadow: var(--shadow); }
.qtable thead th {
  text-align: left; font-family: var(--font-ui); font-size: 0.625rem; font-weight: 500;
  letter-spacing: 0.15em; text-transform: uppercase; color: var(--grey-500);
  padding: 16px 20px; border-bottom: 1px solid var(--grey-300); background: var(--grey-200);
}
.qtable tbody td { padding: 18px 20px; border-bottom: 1px solid var(--grey-200); vertical-align: middle; }
.qtable tbody tr { cursor: pointer; transition: background 200ms var(--ease); }
.qtable tbody tr:hover { background: var(--bronze-10); }
.qtable tbody tr:last-child td { border-bottom: none; }
.q-company { font-family: var(--font-heading); font-size: 1.0625rem; color: var(--charcoal-dark); }
.q-sub { font-family: var(--font-ui); font-size: 0.75rem; color: var(--grey-600); margin-top: 2px; }
.q-chevron { stroke: var(--grey-400); width: 18px; height: 18px; fill: none; stroke-width: 1.5; transition: transform 240ms var(--ease); }
.qtable tbody tr:hover .q-chevron { transform: translateX(3px); stroke: var(--bronze-dark); }
.flag-spam { font-family: var(--font-ui); font-size: 0.625rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--reject); border: 1px solid var(--reject-bg); padding: 2px 6px; }

/* ============================================================================
   Dossier
   ============================================================================ */
.dossier { display: grid; grid-template-columns: 1fr 360px; gap: 28px; align-items: start; }
.backlink { display: inline-flex; align-items: center; gap: 8px; font-family: var(--font-ui); font-size: 0.75rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--grey-600); margin-bottom: 20px; transition: color 200ms var(--ease); }
.backlink:hover { color: var(--bronze-dark); }
.backlink svg { width: 14px; height: 14px; stroke: currentColor; fill: none; stroke-width: 1.5; }

.lead-head { margin-bottom: 28px; }
.lead-head h1 { font-size: 2.5rem; margin: 6px 0 14px; }
.lead-meta { display: flex; flex-wrap: wrap; gap: 8px 28px; font-family: var(--font-ui); font-size: 0.8125rem; color: var(--charcoal-lt); }
.lead-meta a { color: var(--bronze-dark); border-bottom: 1px solid var(--bronze-20); }
.lead-meta .k { color: var(--grey-500); margin-right: 6px; }

.criterion { padding: 18px 0; border-bottom: 1px solid var(--grey-200); }
.criterion:last-child { border-bottom: none; }
.criterion__top { display: flex; align-items: center; gap: 14px; margin-bottom: 8px; }
.criterion__name { font-family: var(--font-ui); font-size: 0.8125rem; font-weight: 500; letter-spacing: 0.08em; text-transform: uppercase; color: var(--charcoal-dark); }
.criterion__wt { font-family: var(--font-ui); font-size: 0.6875rem; color: var(--grey-500); }
.score-track { flex: 1; height: 5px; background: var(--grey-300); max-width: 200px; position: relative; }
.score-fill { position: absolute; inset: 0 auto 0 0; background: var(--bronze); animation: grow 900ms var(--ease) both; }
.criterion__score { font-family: var(--font-heading); font-size: 1.125rem; color: var(--charcoal-dark); min-width: 30px; text-align: right; }
.criterion__ev { font-size: 0.9375rem; color: var(--charcoal-lt); }
.criterion__src { font-family: var(--font-ui); font-size: 0.75rem; color: var(--bronze-dark); margin-top: 4px; display: inline-block; }

.reasoning {
  font-family: var(--font-body); font-size: 0.9375rem; line-height: 1.75; color: var(--charcoal-lt);
  background: var(--grey-200); border-left: 2px solid var(--bronze); padding: 20px 24px;
}
.sources-list { list-style: none; }
.sources-list li { padding: 9px 0; border-bottom: 1px solid var(--grey-200); font-family: var(--font-ui); font-size: 0.8125rem; }
.sources-list li:last-child { border-bottom: none; }
.sources-list a { color: var(--bronze-dark); }

/* Recommendation rail */
.rail { position: sticky; top: 100px; display: flex; flex-direction: column; gap: 20px; }
.reco {
  background: var(--charcoal-dark); color: var(--offwhite); padding: 28px 26px;
}
.reco .eyebrow { color: var(--bronze-light); }
.reco__decision { font-family: var(--font-heading); font-size: 2rem; margin: 10px 0 4px; color: var(--white); text-transform: capitalize; }
.reco__conf { display: flex; align-items: center; gap: 12px; margin: 16px 0 20px; }
.reco__conf .ring { --p: 78; width: 54px; height: 54px; border-radius: 50%; display: grid; place-items: center; background: conic-gradient(var(--bronze) calc(var(--p)*1%), rgba(255,255,255,0.12) 0); position: relative; }
.reco__conf .ring::after { content: ''; position: absolute; inset: 5px; border-radius: 50%; background: var(--charcoal-dark); }
.reco__conf .ring b { position: relative; z-index: 1; font-family: var(--font-heading); font-size: 0.9375rem; color: var(--white); }
.reco__conf .lab { font-family: var(--font-ui); font-size: 0.75rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--bronze-light); }
.reco__summary { font-size: 0.9375rem; line-height: 1.65; color: rgba(242,242,242,0.85); border-top: 1px solid rgba(255,255,255,0.12); padding-top: 16px; }
.reco__webpres { font-family: var(--font-ui); font-size: 0.75rem; letter-spacing: 0.05em; color: var(--bronze-light); margin-top: 14px; }

.actions .label { display: block; margin-bottom: 12px; }
.action-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin-bottom: 14px; }
.act {
  font-family: var(--font-ui); font-size: 0.75rem; font-weight: 500; letter-spacing: 0.08em; text-transform: uppercase;
  padding: 13px 10px; border: 1.5px solid var(--grey-300); background: var(--white); color: var(--grey-600);
  cursor: pointer; transition: all 220ms var(--ease); text-align: center;
}
.act:hover { border-color: var(--charcoal); color: var(--charcoal-dark); }
.act.is-selected { border-color: var(--approve); background: var(--approve-bg); color: var(--approve); }
.act.is-selected[data-d="reject"] { border-color: var(--reject); background: var(--reject-bg); color: var(--reject); }
.act.is-selected[data-d="non_design"] { border-color: var(--nondesign); background: var(--nondesign-bg); color: var(--nondesign); }
.act.is-selected[data-d="follow_up"] { border-color: var(--followup); background: var(--followup-bg); color: var(--followup); }
.act__match { font-family: var(--font-ui); font-size: 0.5625rem; letter-spacing: 0.12em; color: var(--bronze-dark); display: block; margin-top: 3px; }
.note { width: 100%; border: 1px solid var(--grey-300); padding: 12px 14px; font-family: var(--font-body); font-size: 0.9375rem; resize: vertical; min-height: 70px; outline: none; }
.note:focus { border-color: var(--bronze); }

/* ============================================================================
   Dashboard
   ============================================================================ */
.dash-grid { display: grid; grid-template-columns: 1.4fr 1fr; gap: 28px; align-items: start; }
.matrix { width: 100%; border-collapse: collapse; }
.matrix th, .matrix td { padding: 12px 10px; text-align: center; font-family: var(--font-ui); font-size: 0.8125rem; }
.matrix thead th { font-size: 0.625rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--grey-500); border-bottom: 1px solid var(--grey-300); }
.matrix tbody th { text-align: right; font-size: 0.625rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--grey-500); padding-right: 16px; }
.matrix td { border: 1px solid var(--grey-200); color: var(--charcoal); }
.matrix td.diag { background: var(--bronze-10); font-family: var(--font-heading); color: var(--bronze-dark); }
.matrix td.hot { background: var(--bronze-20); }
.matrix td.zero { color: var(--grey-400); }

.breakdown { display: flex; flex-direction: column; gap: 14px; }
.bd-row { display: grid; grid-template-columns: 110px 1fr 44px; align-items: center; gap: 14px; }
.bd-row .label { color: var(--charcoal-lt); }
.bd-track { height: 8px; background: var(--grey-200); position: relative; }
.bd-fill { position: absolute; inset: 0 auto 0 0; animation: grow 1s var(--ease) both; }
.bd-num { font-family: var(--font-heading); font-size: 0.9375rem; text-align: right; color: var(--charcoal-dark); }

.phase-track { display: flex; align-items: center; gap: 0; margin: 8px 0 4px; }
.phase-step { flex: 1; text-align: center; position: relative; }
.phase-step__dot { width: 14px; height: 14px; border-radius: 50%; background: var(--grey-300); margin: 0 auto 12px; border: 2px solid var(--paper); position: relative; z-index: 1; }
.phase-step.done .phase-step__dot { background: var(--bronze); }
.phase-step.current .phase-step__dot { background: var(--charcoal-dark); box-shadow: 0 0 0 4px var(--bronze-20); }
.phase-step::before { content: ''; position: absolute; top: 6px; left: -50%; width: 100%; height: 2px; background: var(--grey-300); z-index: 0; }
.phase-step:first-child::before { display: none; }
.phase-step.done::before, .phase-step.current::before { background: var(--bronze); }
.phase-step__name { font-family: var(--font-ui); font-size: 0.75rem; letter-spacing: 0.08em; text-transform: uppercase; color: var(--grey-600); }
.phase-step.current .phase-step__name { color: var(--charcoal-dark); font-weight: 500; }

.note-banner { background: var(--followup-bg); border: 1px solid rgba(196,151,61,0.3); padding: 14px 18px; font-family: var(--font-ui); font-size: 0.8125rem; color: var(--bronze-dark); margin-bottom: 24px; display: flex; gap: 10px; align-items: center; }
.note-banner svg { width: 16px; height: 16px; stroke: currentColor; fill: none; stroke-width: 1.5; flex-shrink: 0; }

/* ============================================================================
   Rubric editor
   ============================================================================ */
.crit-edit { display: grid; grid-template-columns: 1fr 200px; gap: 24px; padding: 22px 0; border-bottom: 1px solid var(--grey-200); align-items: start; }
.crit-edit textarea { width: 100%; border: 1px solid var(--grey-300); padding: 10px 13px; font-family: var(--font-body); font-size: 0.9375rem; resize: vertical; min-height: 56px; outline: none; }
.crit-edit textarea:focus { border-color: var(--bronze); }
.weight-box { display: flex; flex-direction: column; gap: 8px; }
.range { -webkit-appearance: none; appearance: none; width: 100%; height: 3px; background: var(--grey-300); outline: none; }
.range::-webkit-slider-thumb { -webkit-appearance: none; width: 16px; height: 16px; background: var(--bronze-dark); cursor: pointer; border-radius: 0; }
.weight-val { font-family: var(--font-heading); font-size: 1.25rem; color: var(--charcoal-dark); }
.sumbar { display: flex; align-items: center; gap: 12px; margin-top: 20px; padding: 14px 18px; background: var(--approve-bg); border: 1px solid rgba(90,122,90,0.25); font-family: var(--font-ui); font-size: 0.8125rem; color: var(--approve); }

/* version history */
.versions { list-style: none; }
.ver { display: flex; gap: 14px; padding: 14px 0; border-bottom: 1px solid var(--grey-200); }
.ver__v { font-family: var(--font-heading); font-size: 1.125rem; color: var(--bronze-dark); min-width: 36px; }
.ver__meta { font-family: var(--font-ui); font-size: 0.75rem; color: var(--grey-600); }
.ver.is-active .ver__v { color: var(--charcoal-dark); }

/* ---- staggered entrance ---- */
.reveal { opacity: 0; transform: translateY(12px); animation: rise 700ms var(--ease) forwards; }
@keyframes rise { to { opacity: 1; transform: none; } }
.d1 { animation-delay: 60ms; } .d2 { animation-delay: 130ms; } .d3 { animation-delay: 200ms; }
.d4 { animation-delay: 270ms; } .d5 { animation-delay: 340ms; } .d6 { animation-delay: 410ms; }

@media (prefers-reduced-motion: reduce) {
  .reveal { opacity: 1; transform: none; animation: none; }
  .conf__fill, .score-fill, .bd-fill { animation: none; }
  .phase-badge .dot { animation: none; }
}

.mock-flag {
  position: fixed; bottom: 14px; right: 14px; z-index: 50;
  font-family: var(--font-ui); font-size: 0.625rem; letter-spacing: 0.15em; text-transform: uppercase;
  background: var(--charcoal-dark); color: var(--bronze-light); padding: 7px 13px;
}

@media (max-width: 1080px) {
  .app { grid-template-columns: 1fr; }
  .sidebar { position: static; height: auto; flex-direction: row; align-items: center; overflow-x: auto; }
  .sidebar__brand { border-bottom: none; border-right: 1px solid var(--grey-300); }
  .nav { display: flex; padding: 10px; }
  .nav__group { margin: 0; display: flex; }
  .nav__heading { display: none; }
  .sidebar__foot { display: none; }
  .dossier, .dash-grid { grid-template-columns: 1fr; }
  .rail { position: static; }
  .content { padding: 24px 20px 48px; }
  .topbar { padding: 18px 20px; }
}

/* ---- Phone (<=600px): tighten chrome and reflow the wide queue table into cards ---- */
@media (max-width: 600px) {
  html, body { overflow-x: hidden; }
  .app, .main, .content { max-width: 100vw; min-width: 0; }
  .sidebar { flex-wrap: wrap; overflow-x: visible; }
  .sidebar__brand { padding: 16px 18px; border-right: none; }
  .sidebar__brand img { height: 38px; }
  .nav { flex-wrap: wrap; }
  .nav__item { padding: 8px 12px; font-size: 0.8rem; }
  .topbar { flex-wrap: wrap; gap: 6px; }
  .topbar__spacer { display: none; }
  .topbar h1 { font-size: 1.4rem; }
  .phase-badge { font-size: 0.62rem; }
  .content { padding: 18px 14px 44px; }
  .kpis { grid-template-columns: 1fr; }
  .filters { gap: 10px; }
  .filters .search { width: 100%; }
  .chips { flex-wrap: wrap; }
  .decide-grid { grid-template-columns: 1fr; }
  /* dossier tidy-ups */
  .lead-meta { flex-direction: column; gap: 8px; }
  .lead-head .eyebrow { white-space: normal; }
  .criterion__top { flex-wrap: wrap; gap: 6px 10px; }
  .criterion__top .score-track { order: 3; flex: 1 0 100%; }
  .reco, .actions, .card--pad { padding-left: 20px; padding-right: 20px; }

  /* qtable -> stacked cards */
  .qtable, .qtable tbody, .qtable tr, .qtable td { display: block; width: 100%; }
  .qtable thead { position: absolute; left: -9999px; }            /* visually hide header row */
  .qtable { border: none; box-shadow: none; background: transparent; }
  .qtable tbody tr { border: 1px solid var(--grey-300); background: var(--white); box-shadow: var(--shadow); margin-bottom: 14px; padding: 8px 4px; }
  /* Stacked layout (label above value) — no flex, so no horizontal overflow on narrow screens. */
  .qtable tbody td { border: none; padding: 6px 16px; max-width: 100%; overflow-wrap: anywhere; }
  .qtable tbody td::before {
    content: attr(data-label);
    display: block; margin-bottom: 3px;
    font-family: var(--font-ui); font-size: 0.6rem; font-weight: 500;
    letter-spacing: 0.12em; text-transform: uppercase; color: var(--grey-500);
  }
  .qtable td.q-cell-company { padding: 4px 16px 8px; border-bottom: 1px solid var(--grey-200); margin-bottom: 4px; }
  .qtable td.q-cell-company::before { display: none; }
  .qtable td.q-cell-chevron { display: none; }
  .conf { width: auto; }
}

/* ============================================================================
   Console runtime additions (login screen, form helpers) — live app only
   ============================================================================ */
.login-wrap { min-height: 100vh; display: grid; place-items: center; background: var(--paper); padding: 24px; }
.login-card { width: 100%; max-width: 400px; background: var(--white); border: 1px solid var(--grey-300); box-shadow: var(--shadow-lg); }
.login-card__brand { background: var(--charcoal-dark); padding: 30px 36px; }
.login-card__brand img { height: 46px; width: auto; display: block; }
.login-card__brand .sidebar__tag { color: var(--bronze-light); margin-top: 14px; }
.login-card__body { padding: 34px 36px 38px; }
.login-card__body h1 { font-size: 1.5rem; margin-bottom: 4px; }
.field { display: block; margin: 18px 0; }
.field span { display: block; font-family: var(--font-ui); font-size: 0.6875rem; font-weight: 500; letter-spacing: 0.12em; text-transform: uppercase; color: var(--grey-600); margin-bottom: 7px; }
.field input { width: 100%; border: 1px solid var(--grey-300); padding: 12px 14px; font-family: var(--font-ui); font-size: 0.9375rem; outline: none; background: var(--white); color: var(--charcoal); }
.field input:focus { border-color: var(--bronze); }
.form-error { font-family: var(--font-ui); font-size: 0.8125rem; color: var(--reject); background: var(--reject-bg); border: 1px solid rgba(160,64,64,0.25); padding: 10px 14px; margin-bottom: 16px; }
.muted { font-family: var(--font-ui); font-size: 0.75rem; color: var(--grey-500); }

/* decision radios styled as the mockup action buttons */
.decide-grid { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 8px; margin: 12px 0 16px; }
.decide-opt { position: relative; }
.decide-opt input { position: absolute; opacity: 0; pointer-events: none; }
.decide-opt span { display: block; text-align: center; cursor: pointer; padding: 13px 8px;
  font-family: var(--font-ui); font-size: 0.75rem; font-weight: 500; letter-spacing: 0.08em; text-transform: uppercase;
  border: 1.5px solid var(--grey-300); background: var(--white); color: var(--grey-600); transition: all 220ms var(--ease); }
.decide-opt:hover span { border-color: var(--charcoal); color: var(--charcoal-dark); }
.decide-opt input:checked + span { border-color: var(--bronze-dark); background: var(--bronze-10); color: var(--charcoal-dark); }

/* dossier reasoning as preformatted */
.reasoning-pre { font-family: var(--font-body); font-size: 0.9375rem; line-height: 1.75; color: var(--charcoal-lt);
  background: var(--grey-200); border-left: 2px solid var(--bronze); padding: 20px 24px; white-space: pre-wrap; }
.empty-state { font-family: var(--font-body); color: var(--grey-600); padding: 40px; text-align: center; background: var(--white); border: 1px solid var(--grey-300); }
