/* =============================================================================
   1891 Interpreter — marketing interactivity layer
   Scroll-reveal, hover polish, and widget styles. Sits on top of site.css.
   All animations respect prefers-reduced-motion.
   ============================================================================= */

/* -----------------------------------------------------------------------------
   Scroll-reveal
   ---------------------------------------------------------------------------*/
[data-reveal] {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 600ms var(--1891int-ease, cubic-bezier(.16,1,.3,1)),
              transform 600ms var(--1891int-ease, cubic-bezier(.16,1,.3,1));
  will-change: opacity, transform;
}
[data-reveal].is-visible {
  opacity: 1;
  transform: translateY(0);
}
/* Stagger via data-delay attribute */
[data-reveal][data-delay="100"] { transition-delay: 100ms; }
[data-reveal][data-delay="200"] { transition-delay: 200ms; }
[data-reveal][data-delay="300"] { transition-delay: 300ms; }
[data-reveal][data-delay="400"] { transition-delay: 400ms; }
[data-reveal][data-delay="500"] { transition-delay: 500ms; }
[data-reveal][data-delay="600"] { transition-delay: 600ms; }

/* -----------------------------------------------------------------------------
   Hover polish — card, button, stat, comparison, pillar, eyebrow
   ---------------------------------------------------------------------------*/
.card-hoverable {
  transition: transform 320ms var(--1891int-ease, cubic-bezier(.16,1,.3,1)),
              box-shadow 320ms var(--1891int-ease, cubic-bezier(.16,1,.3,1)),
              border-color 320ms var(--1891int-ease, cubic-bezier(.16,1,.3,1)),
              padding 320ms var(--1891int-ease, cubic-bezier(.16,1,.3,1));
  will-change: transform;
}
.card-hoverable:hover {
  transform: translateY(-6px) scale(1.012);
  box-shadow:
    0 32px 64px -16px rgba(15,20,25,.22),
    0 8px 16px -8px rgba(200,85,61,.12);
  border-color: var(--1891int-bloom-soft);
}
/* The text-bloom "→" arrow inside hoverable cards nudges right on hover */
.card-hoverable .text-bloom {
  transition: transform 320ms var(--1891int-ease, cubic-bezier(.16,1,.3,1));
}
.card-hoverable:hover .text-bloom {
  transform: translateX(4px);
}
/* Pillar gets the same breathing pattern as card-hoverable for consistency */
.pillar {
  transition: transform 320ms var(--1891int-ease, cubic-bezier(.16,1,.3,1)),
              box-shadow 320ms var(--1891int-ease, cubic-bezier(.16,1,.3,1)),
              border-color 320ms var(--1891int-ease, cubic-bezier(.16,1,.3,1));
}
.pillar:hover {
  transform: translateY(-4px);
  box-shadow: 0 24px 48px -16px rgba(15,20,25,.16);
}

.btn-primary:hover {
  box-shadow: 0 10px 28px rgba(200,85,61,.32), 0 1px 2px rgba(15,20,25,.06);
}

.stat,
.num,
[data-countup] {
  transition: transform 240ms var(--1891int-ease, cubic-bezier(.16,1,.3,1)),
              color 240ms var(--1891int-ease, cubic-bezier(.16,1,.3,1));
  display: inline-block;
}
.stat:hover,
.stat:hover .num,
[data-countup]:hover {
  transform: scale(1.05);
}

/* Comparison table row hover */
table.compare tbody tr {
  transition: background-color 180ms var(--1891int-ease, cubic-bezier(.16,1,.3,1));
}
table.compare tbody tr:hover {
  background: var(--1891int-paper-warm);
}
table.compare tbody tr:hover td.own {
  background: var(--1891int-bloom-soft);
}

/* Pillar pulse — when parent card hovers, the giant number pulses */
.pillar { transition: border-color 280ms var(--1891int-ease, cubic-bezier(.16,1,.3,1)); }
.pillar:hover { border-color: var(--1891int-bloom-soft); }
.pillar .pillar-num {
  transition: color 280ms var(--1891int-ease, cubic-bezier(.16,1,.3,1)),
              transform 280ms var(--1891int-ease, cubic-bezier(.16,1,.3,1));
}
.pillar:hover .pillar-num {
  color: var(--1891int-bloom-soft);
  animation: pillar-pulse 1400ms ease-in-out infinite;
}
@keyframes pillar-pulse {
  0%, 100% { transform: scale(1); }
  50%      { transform: scale(1.06); }
}

/* Eyebrow gets a left-border slide-in on hover of its container */
.eyebrow {
  position: relative;
  padding-left: 0;
  transition: padding-left 240ms var(--1891int-ease, cubic-bezier(.16,1,.3,1));
}
.eyebrow::before {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  height: 70%;
  width: 0;
  background: var(--1891int-bloom);
  transform: translateY(-50%);
  transition: width 240ms var(--1891int-ease, cubic-bezier(.16,1,.3,1));
}
:hover > .eyebrow,
.eyebrow:hover {
  padding-left: 14px;
}
:hover > .eyebrow::before,
.eyebrow:hover::before {
  width: 4px;
}

/* -----------------------------------------------------------------------------
   Brand-mark hover — ASL contact dot pulses
   ---------------------------------------------------------------------------*/
.brand .brand-mark,
img.brand-mark {
  transition: transform 320ms var(--1891int-ease, cubic-bezier(.16,1,.3,1));
}
.brand:hover .brand-mark {
  transform: rotate(-3deg) scale(1.06);
  animation: arc-pulse 1200ms ease-in-out infinite;
}
@keyframes arc-pulse {
  0%, 100% { filter: drop-shadow(0 0 0 rgba(200,85,61,0)); }
  50%      { filter: drop-shadow(0 0 8px rgba(200,85,61,.55)); }
}

/* Hero illustration gentle float */
.hero .asl-frame,
.hero [data-float] {
  animation: gentle-float 7s ease-in-out infinite;
}
@keyframes gentle-float {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(-6px); }
}

/* -----------------------------------------------------------------------------
   Widget — shared chrome
   ---------------------------------------------------------------------------*/
/* Widget showcase grid — strict 2-up on desktop so widgets get ~50% each
   instead of auto-fit's 3+1 wrap. Stacks to 1 column on narrow viewports. */
@media (max-width: 760px) {
  .widget-showcase { grid-template-columns: 1fr !important; }
}

/* Each cell of the showcase grid gets a clearly-outlined card.
   Header copy + interactive widget live inside the same tile so the
   boundary between adjacent tiles is unambiguous. */
.showcase-tile {
  background: var(--1891int-paper);
  border: 1px solid var(--1891int-line);
  border-radius: var(--1891int-radius-lg);
  padding: var(--1891int-s-6);
  box-shadow: var(--1891int-shadow-sm);
  display: flex;
  flex-direction: column;
  gap: var(--1891int-s-3);
  transition: transform 320ms var(--1891int-ease, cubic-bezier(.16,1,.3,1)),
              box-shadow 320ms var(--1891int-ease, cubic-bezier(.16,1,.3,1)),
              border-color 320ms var(--1891int-ease, cubic-bezier(.16,1,.3,1));
}
.showcase-tile:hover {
  transform: translateY(-4px);
  box-shadow:
    0 32px 64px -16px rgba(15,20,25,.18),
    0 8px 16px -8px rgba(200,85,61,.10);
  border-color: var(--1891int-bloom-soft);
}
.showcase-tile > h3 {
  margin: 0;
  font-size: 19px;
  line-height: 1.3;
}
.showcase-tile > p {
  margin: 0;
  font-size: 14.5px;
  color: var(--1891int-ink-soft);
  line-height: 1.55;
}
.showcase-tile > .eyebrow {
  margin: 0;
}
/* The inner widget loses its own card chrome — the outer tile owns the box.
   The widget instead sits on a slightly-inset deeper paper so it reads as
   the interactive surface within the framed tile. */
.showcase-tile > .widget {
  background: var(--1891int-paper-warm);
  border: 1px solid var(--1891int-paper-deep);
  border-radius: var(--1891int-radius-md);
  padding: var(--1891int-s-5);
  box-shadow: none;
  margin-top: var(--1891int-s-3);
}
.showcase-tile > .widget:hover {
  /* Don't double-lift inside an already-lifting tile */
  transform: none;
  box-shadow: none;
  border-color: var(--1891int-paper-deep);
}

.widget {
  background: var(--1891int-paper);
  border: 1px solid var(--1891int-line);
  border-radius: var(--1891int-radius-lg);
  padding: var(--1891int-s-5);
  box-shadow: var(--1891int-shadow-sm);
  position: relative;
  overflow: hidden;
  transition: transform 320ms var(--1891int-ease, cubic-bezier(.16,1,.3,1)),
              box-shadow 320ms var(--1891int-ease, cubic-bezier(.16,1,.3,1)),
              border-color 320ms var(--1891int-ease, cubic-bezier(.16,1,.3,1));
}
.widget:hover {
  transform: translateY(-3px);
  box-shadow: 0 26px 56px rgba(15,20,25,.12);
  border-color: var(--1891int-bloom-soft);
}
.widget-frame {
  background: var(--1891int-paper-warm);
  border-radius: var(--1891int-radius-md);
  padding: var(--1891int-s-5);
  border: 1px solid var(--1891int-line);
}
.widget-controls {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--1891int-s-3);
  margin-bottom: var(--1891int-s-4);
}
.widget-controls > .full { grid-column: 1 / -1; }
@media (max-width: 380px) {
  .widget-controls { grid-template-columns: 1fr; }
}
.widget-title {
  font-family: var(--1891int-display);
  font-size: 20px;
  font-weight: 700;
  color: var(--1891int-ink);
  margin: 0 0 var(--1891int-s-3);
}
.widget-caption {
  font-size: 13px;
  color: var(--1891int-fog);
  margin-top: var(--1891int-s-4);
  display: block;
}
.widget label {
  display: block;
  font-weight: 600;
  font-size: 13px;
  color: var(--1891int-ink-soft);
  margin-bottom: 4px;
  text-transform: uppercase;
  letter-spacing: .06em;
}
.widget select,
.widget input[type="text"],
.widget input[type="number"] {
  padding: 8px 12px;
  font-size: 14.5px;
  border-radius: var(--1891int-radius-sm);
  border: 1px solid var(--1891int-line);
  background: var(--1891int-paper);
  color: var(--1891int-ink);
  font-family: var(--1891int-body);
}
.widget select:focus,
.widget input:focus {
  outline: 0;
  border-color: var(--1891int-bloom);
  box-shadow: 0 0 0 3px var(--1891int-bloom-tint);
}

/* Chip group (time-of-day) — single row, smaller chips so the widget breathes */
.widget-chips {
  display: flex;
  flex-wrap: nowrap;
  gap: 3px;
  padding: 3px;
  border-radius: var(--1891int-radius-pill);
  background: var(--1891int-paper-deep);
  border: 1px solid var(--1891int-line);
  width: 100%;
  overflow-x: auto;
}
.widget-chips button {
  background: transparent;
  flex: 1 1 auto;
  white-space: nowrap;
  border: 0;
  padding: 6px 10px;
  border-radius: var(--1891int-radius-pill);
  font-size: 12.5px;
  font-weight: 600;
  color: var(--1891int-ink-soft);
  cursor: pointer;
  transition: background-color 180ms var(--1891int-ease, cubic-bezier(.16,1,.3,1)),
              color 180ms var(--1891int-ease, cubic-bezier(.16,1,.3,1));
}
.widget-chips button:hover { color: var(--1891int-ink); }
.widget-chips button[aria-pressed="true"] {
  background: var(--1891int-bloom);
  color: #fff;
}

/* Modifier chips (rate explainer pills) */
.widget-mods {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: var(--1891int-s-3);
  min-height: 28px;
}
.widget-mod {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 10px;
  border-radius: var(--1891int-radius-pill);
  background: var(--1891int-river-tint);
  color: var(--1891int-river-deep);
  border: 1px solid var(--1891int-river-soft);
  font-size: 12.5px;
  font-weight: 600;
  font-family: var(--1891int-mono);
  animation: chip-in 280ms var(--1891int-ease, cubic-bezier(.16,1,.3,1)) both;
}
.widget-mod.is-neg { background: #FBEDEB; color: var(--1891int-bloom-deep); border-color: var(--1891int-bloom-soft); }
@keyframes chip-in {
  from { opacity: 0; transform: translateY(4px) scale(.95); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}

/* Big number columns used by rate + cancel widgets */
.widget-figures {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--1891int-s-3);
  margin-top: var(--1891int-s-4);
}
.widget-fig {
  background: var(--1891int-paper);
  border: 1px solid var(--1891int-line);
  border-radius: var(--1891int-radius-md);
  padding: 12px 14px;
  text-align: center;
  min-width: 0;
}
.widget-fig .lbl {
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--1891int-fog);
  font-weight: 700;
  display: block;
  margin-bottom: 4px;
  line-height: 1.25;
}
.widget-fig .val {
  font-family: var(--1891int-display);
  font-size: clamp(22px, 2.6vw, 30px);
  font-weight: 700;
  line-height: 1;
  color: var(--1891int-ink);
  transition: color 200ms var(--1891int-ease, cubic-bezier(.16,1,.3,1));
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}
.widget-fig.is-bloom .val { color: var(--1891int-bloom-deep); }
.widget-fig.is-river .val { color: var(--1891int-river-deep); }

/* -----------------------------------------------------------------------------
   Widget — lifecycle
   ---------------------------------------------------------------------------*/
.lifecycle-card {
  background: var(--1891int-paper);
  border: 1px solid var(--1891int-line);
  border-radius: var(--1891int-radius-md);
  padding: var(--1891int-s-5);
  position: relative;
}
.lifecycle-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 5px 12px;
  border-radius: var(--1891int-radius-pill);
  font-size: 12.5px;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  background: var(--1891int-paper-deep);
  color: var(--1891int-ink-soft);
  border: 1px solid var(--1891int-line);
  transition: background-color 320ms var(--1891int-ease, cubic-bezier(.16,1,.3,1)),
              color 320ms var(--1891int-ease, cubic-bezier(.16,1,.3,1)),
              border-color 320ms var(--1891int-ease, cubic-bezier(.16,1,.3,1));
}
.lifecycle-chip::before {
  content: "";
  width: 8px; height: 8px;
  border-radius: 50%;
  background: currentColor;
  animation: dot-pulse 1.6s ease-in-out infinite;
}
@keyframes dot-pulse {
  0%, 100% { opacity: .7; transform: scale(1); }
  50%      { opacity: 1; transform: scale(1.3); }
}
.lifecycle-chip[data-state="OPEN"]        { background:#FFF6E0; color:#7A5300; border-color:#E9D7A4; }
.lifecycle-chip[data-state="OFFERED"]     { background:#EDE6F8; color:#4A2A87; border-color:#C9B8E8; }
.lifecycle-chip[data-state="CLAIMED"]     { background:var(--1891int-river-tint); color:var(--1891int-river-deep); border-color:var(--1891int-river-soft); }
.lifecycle-chip[data-state="CONFIRMED"]   { background:#DCE9E7; color:#1E4544; border-color:#88B0AE; }
.lifecycle-chip[data-state="IN_PROGRESS"] { background:var(--1891int-bloom-tint); color:var(--1891int-bloom-deep); border-color:var(--1891int-bloom-soft); }
.lifecycle-chip[data-state="COMPLETED"]   { background:#E6F3EB; color:var(--1891int-ok); border-color:#B6DCC5; }

.lifecycle-ts {
  font-family: var(--1891int-mono);
  font-size: 12px;
  color: var(--1891int-fog);
  margin-left: var(--1891int-s-3);
}
.lifecycle-job {
  margin-top: var(--1891int-s-4);
  font-family: var(--1891int-display);
  font-size: 18px;
  color: var(--1891int-ink);
  line-height: 1.35;
}
.lifecycle-meta {
  margin-top: var(--1891int-s-2);
  font-size: 14px;
  color: var(--1891int-ink-soft);
}
.lifecycle-progress {
  display: flex;
  gap: 4px;
  margin-top: var(--1891int-s-5);
}
.lifecycle-progress span {
  flex: 1;
  height: 4px;
  border-radius: 2px;
  background: var(--1891int-paper-deep);
  transition: background-color 320ms var(--1891int-ease, cubic-bezier(.16,1,.3,1));
}
.lifecycle-progress span.is-done {
  background: var(--1891int-bloom);
}

/* -----------------------------------------------------------------------------
   Widget — cancellation slider
   ---------------------------------------------------------------------------*/
.cancel-slider {
  width: 100%;
  -webkit-appearance: none;
  appearance: none;
  height: 6px;
  border-radius: 3px;
  background: linear-gradient(90deg,
              var(--1891int-ok) 0%, var(--1891int-ok) 33%,
              var(--1891int-warn) 33%, var(--1891int-warn) 66%,
              var(--1891int-bloom) 66%, var(--1891int-bloom) 100%);
  outline: none;
  margin: var(--1891int-s-4) 0 var(--1891int-s-2);
}
.cancel-slider::-webkit-slider-thumb {
  -webkit-appearance: none;
  width: 22px; height: 22px;
  border-radius: 50%;
  background: var(--1891int-ink);
  border: 3px solid #fff;
  box-shadow: 0 2px 6px rgba(15,20,25,.25);
  cursor: pointer;
}
.cancel-slider::-moz-range-thumb {
  width: 22px; height: 22px;
  border-radius: 50%;
  background: var(--1891int-ink);
  border: 3px solid #fff;
  box-shadow: 0 2px 6px rgba(15,20,25,.25);
  cursor: pointer;
}
.cancel-readout {
  display: flex;
  justify-content: space-between;
  font-size: 12px;
  color: var(--1891int-fog);
  font-family: var(--1891int-mono);
}
.cancel-tier {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 14px;
  border-radius: var(--1891int-radius-pill);
  background: var(--1891int-paper-deep);
  color: var(--1891int-ink);
  font-weight: 700;
  font-size: 14px;
  margin-top: var(--1891int-s-3);
  transition: background-color 280ms var(--1891int-ease, cubic-bezier(.16,1,.3,1)),
              color 280ms var(--1891int-ease, cubic-bezier(.16,1,.3,1));
}
.cancel-tier[data-tier="t0"] { background:#E6F3EB; color:var(--1891int-ok); }
.cancel-tier[data-tier="t1"] { background:#FFF6E0; color:#7A5300; }
.cancel-tier[data-tier="t2"] { background:var(--1891int-bloom-tint); color:var(--1891int-bloom-deep); }
.cancel-tier[data-tier="t3"] { background:#FBEDEB; color:var(--1891int-err); }

/* -----------------------------------------------------------------------------
   Widget — SMS phone
   ---------------------------------------------------------------------------*/
.sms-phone {
  max-width: 360px;
  margin: 0 auto;
  background: var(--1891int-paper-warm);
  border-radius: var(--1891int-radius-lg);
  padding: var(--1891int-s-4);
  border: 1px solid var(--1891int-line);
}
.sms-thread {
  display: flex;
  flex-direction: column;
  gap: var(--1891int-s-3);
  min-height: 200px;
  margin-bottom: var(--1891int-s-3);
}
.sms-bubble {
  max-width: 80%;
  padding: 10px 14px;
  border-radius: 16px;
  font-size: 14.5px;
  line-height: 1.4;
  animation: bubble-in 320ms var(--1891int-ease, cubic-bezier(.16,1,.3,1)) both;
}
.sms-bubble.from-agency {
  align-self: flex-start;
  background: var(--1891int-paper);
  color: var(--1891int-ink);
  border: 1px solid var(--1891int-line);
  border-bottom-left-radius: 4px;
}
.sms-bubble.from-user {
  align-self: flex-end;
  background: var(--1891int-river);
  color: #fff;
  border-bottom-right-radius: 4px;
}
@keyframes bubble-in {
  from { opacity: 0; transform: translateY(8px) scale(.96); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}
.sms-form {
  display: flex;
  gap: 6px;
}
.sms-form input {
  flex: 1;
  padding: 10px 12px;
  border-radius: var(--1891int-radius-pill);
  border: 1px solid var(--1891int-line);
  background: var(--1891int-paper);
  font-size: 14px;
}
.sms-form button {
  background: var(--1891int-bloom);
  color: #fff;
  border: 0;
  border-radius: var(--1891int-radius-pill);
  padding: 10px 16px;
  font-weight: 600;
  font-size: 14px;
  cursor: pointer;
  transition: background-color 200ms var(--1891int-ease, cubic-bezier(.16,1,.3,1));
}
.sms-form button:hover { background: var(--1891int-bloom-deep); }
.sms-hint {
  font-size: 12px;
  color: var(--1891int-fog);
  text-align: center;
  margin-top: var(--1891int-s-2);
  font-family: var(--1891int-mono);
}

/* -----------------------------------------------------------------------------
   Widget — client hierarchy tree
   ---------------------------------------------------------------------------*/
.tree {
  font-family: var(--1891int-body);
}
.tree-node {
  margin-bottom: 2px;
}
.tree-header {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  background: var(--1891int-paper);
  border: 1px solid var(--1891int-line);
  border-radius: var(--1891int-radius-md);
  cursor: pointer;
  font-weight: 600;
  color: var(--1891int-ink);
  width: 100%;
  text-align: left;
  font-size: 15px;
  transition: background-color 200ms var(--1891int-ease, cubic-bezier(.16,1,.3,1)),
              border-color 200ms var(--1891int-ease, cubic-bezier(.16,1,.3,1));
}
.tree-header:hover {
  background: var(--1891int-paper-warm);
  border-color: var(--1891int-bloom-soft);
}
.tree-header[aria-expanded="true"] {
  background: var(--1891int-bloom-tint);
  border-color: var(--1891int-bloom-soft);
  color: var(--1891int-bloom-deep);
}
.tree-caret {
  display: inline-block;
  width: 12px;
  transition: transform 240ms var(--1891int-ease, cubic-bezier(.16,1,.3,1));
  color: var(--1891int-bloom);
  font-family: var(--1891int-mono);
  font-weight: 700;
}
.tree-header[aria-expanded="true"] .tree-caret { transform: rotate(90deg); }
.tree-count {
  margin-left: auto;
  font-size: 12px;
  color: var(--1891int-fog);
  font-family: var(--1891int-mono);
  font-weight: 500;
}
.tree-children {
  list-style: none;
  margin: 0;
  padding: 0 0 0 22px;
  overflow: hidden;
  max-height: 0;
  transition: max-height 360ms var(--1891int-ease, cubic-bezier(.16,1,.3,1));
}
.tree-children.is-open {
  max-height: 1000px;
}
.tree-children > li {
  padding: 8px 10px;
  margin-top: 4px;
  border-left: 2px solid var(--1891int-line);
  padding-left: 14px;
  font-size: 14px;
  color: var(--1891int-ink-soft);
  opacity: 0;
  transform: translateX(-6px);
  transition: opacity 320ms var(--1891int-ease, cubic-bezier(.16,1,.3,1)),
              transform 320ms var(--1891int-ease, cubic-bezier(.16,1,.3,1));
}
.tree-children.is-open > li {
  opacity: 1;
  transform: translateX(0);
}
.tree-children.is-open > li:nth-child(1) { transition-delay:  40ms; }
.tree-children.is-open > li:nth-child(2) { transition-delay:  90ms; }
.tree-children.is-open > li:nth-child(3) { transition-delay: 140ms; }
.tree-children.is-open > li:nth-child(4) { transition-delay: 190ms; }
.tree-children.is-open > li:nth-child(5) { transition-delay: 240ms; }
.tree-children .dept-title {
  font-weight: 700;
  color: var(--1891int-ink);
  margin-bottom: 2px;
  display: block;
}
.tree-children .dept-meta {
  font-size: 13px;
  color: var(--1891int-fog);
  display: block;
}
.tree-summary {
  margin-top: var(--1891int-s-4);
  padding: var(--1891int-s-4);
  background: var(--1891int-river-tint);
  border-left: 4px solid var(--1891int-river);
  border-radius: var(--1891int-radius-sm);
  color: var(--1891int-river-deep);
  font-size: 14px;
  font-weight: 600;
}

/* =============================================================================
   PRODUCT MOCKUPS — "show it" layer
   Clickable screenshot-style frames (browser + phone) and the faithful little
   UIs that live inside them. Used across the feature and audience pages so the
   copy is supported by a picture of the actual screen, not just words.
   Everything here is hover-alive; site.css neutralises it under reduced-motion.
   ============================================================================= */

/* ---- Media + prose rows (alternating sides) ---------------------------- */
.feature-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--1891int-s-8);
  align-items: center;
}
.feature-row + .feature-row { margin-top: var(--1891int-s-9); }
.feature-row .fr-prose > :first-child { margin-top: 0; }
.feature-row .fr-prose h2 { margin-bottom: var(--1891int-s-4); }
/* Alternate which side the picture sits on, row to row. */
.feature-row:nth-of-type(even) .fr-media { order: -1; }
@media (max-width: 820px) {
  .feature-row { grid-template-columns: 1fr; gap: var(--1891int-s-6); }
  .feature-row + .feature-row { margin-top: var(--1891int-s-8); }
  .feature-row:nth-of-type(even) .fr-media { order: 0; }
}

/* ---- The frame --------------------------------------------------------- */
.mock {
  position: relative;
  background: var(--1891int-paper);
  border: 1px solid var(--1891int-line);
  border-radius: var(--1891int-radius-lg);
  box-shadow: var(--1891int-shadow-md);
  overflow: hidden;
  transition: transform 360ms var(--1891int-ease, cubic-bezier(.16,1,.3,1)),
              box-shadow 360ms var(--1891int-ease, cubic-bezier(.16,1,.3,1)),
              border-color 360ms var(--1891int-ease, cubic-bezier(.16,1,.3,1));
}
.mock-bar {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 9px 14px;
  background: var(--1891int-paper-warm);
  border-bottom: 1px solid var(--1891int-line);
}
.mock-dots { display: inline-flex; gap: 6px; flex: 0 0 auto; }
.mock-dots span { width: 10px; height: 10px; border-radius: 50%; display: block; }
.mock-dots span:nth-child(1) { background: #E0938B; }
.mock-dots span:nth-child(2) { background: #E4CB86; }
.mock-dots span:nth-child(3) { background: #9DC6AC; }
.mock-tab {
  font-size: 12.5px;
  color: var(--1891int-fog);
  background: var(--1891int-paper);
  border: 1px solid var(--1891int-line);
  border-radius: var(--1891int-radius-pill);
  padding: 3px 14px;
  margin-left: 4px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  max-width: 70%;
}
.mock-body { padding: var(--1891int-s-5); }

/* A subtle terracotta wash behind every frame so it reads as a "shot" */
.fr-media, .mock-stage {
  position: relative;
}
.mock-stage::before {
  content: "";
  position: absolute;
  inset: -10% -6% -14% -6%;
  background:
    radial-gradient(60% 60% at 78% 0%, var(--1891int-bloom-tint) 0%, transparent 60%),
    radial-gradient(55% 55% at 10% 100%, var(--1891int-river-tint) 0%, transparent 62%);
  z-index: -1;
  opacity: .8;
  border-radius: var(--1891int-radius-lg);
}

/* ---- Clickable frame (wrapped in <a>) ---------------------------------- */
a.mock { text-decoration: none; color: inherit; display: block; cursor: pointer; }
a.mock:hover {
  transform: translateY(-7px);
  box-shadow:
    0 40px 80px -26px rgba(15,20,25,.32),
    0 10px 22px -12px rgba(200,85,61,.20);
  border-color: var(--1891int-bloom-soft);
}
a.mock:focus-visible { outline: 3px solid var(--1891int-bloom); outline-offset: 4px; }
.mock-open {
  position: absolute;
  left: 50%; bottom: 16px;
  transform: translate(-50%, 10px);
  display: inline-flex; align-items: center; gap: 7px;
  background: var(--1891int-bloom);
  color: #fff;
  font-size: 13.5px; font-weight: 600;
  padding: 9px 18px;
  border-radius: var(--1891int-radius-pill);
  box-shadow: 0 12px 28px rgba(200,85,61,.40);
  opacity: 0; pointer-events: none;
  transition: opacity 300ms var(--1891int-ease, cubic-bezier(.16,1,.3,1)),
              transform 300ms var(--1891int-ease, cubic-bezier(.16,1,.3,1));
  z-index: 4;
}
.mock-open .mock-open-arrow { transition: transform 300ms var(--1891int-ease, cubic-bezier(.16,1,.3,1)); }
a.mock:hover .mock-open, a.mock:focus-visible .mock-open {
  opacity: 1; transform: translate(-50%, 0);
}
a.mock:hover .mock-open .mock-open-arrow { transform: translateX(4px); }
/* The body dims a touch on hover so the "open demo" pill pops */
a.mock .mock-body { transition: filter 300ms var(--1891int-ease, cubic-bezier(.16,1,.3,1)); }
a.mock:hover .mock-body { filter: saturate(1.04) contrast(1.01); }

/* ---- Phone frame ------------------------------------------------------- */
.mock-phone {
  max-width: 300px;
  margin: 0 auto;
  border-radius: 30px;
  border: 8px solid #1b2026;
  background: #1b2026;
  box-shadow: var(--1891int-shadow-lg);
  overflow: hidden;
  position: relative;
  transition: transform 360ms var(--1891int-ease, cubic-bezier(.16,1,.3,1)),
              box-shadow 360ms var(--1891int-ease, cubic-bezier(.16,1,.3,1));
}
.mock-phone:hover { transform: translateY(-7px) rotate(-.6deg); box-shadow: 0 44px 80px -24px rgba(15,20,25,.40); }
.mock-phone .mock-notch {
  position: absolute; top: 0; left: 50%; transform: translateX(-50%);
  width: 120px; height: 22px;
  background: #1b2026;
  border-bottom-left-radius: 12px; border-bottom-right-radius: 12px;
  z-index: 5;
}
.mock-screen {
  background: var(--1891int-paper);
  border-radius: 22px;
  overflow: hidden;
  padding: 26px var(--1891int-s-4) var(--1891int-s-4);
}

/* =============================================================================
   Reusable mini-UI atoms used inside the frames
   ============================================================================= */
.ui-toolbar {
  display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
  padding-bottom: var(--1891int-s-3);
  margin-bottom: var(--1891int-s-3);
  border-bottom: 1px solid var(--1891int-line);
}
.ui-search {
  flex: 1 1 130px;
  font-size: 12.5px; color: var(--1891int-fog);
  background: var(--1891int-paper-warm);
  border: 1px solid var(--1891int-line);
  border-radius: var(--1891int-radius-pill);
  padding: 6px 12px;
}
.ui-search::before { content: "⌕  "; color: var(--1891int-bloom); }

.mchip {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 3px 10px;
  border-radius: var(--1891int-radius-pill);
  font-size: 11.5px; font-weight: 700;
  letter-spacing: .02em;
  background: var(--1891int-paper-deep);
  color: var(--1891int-ink-soft);
  border: 1px solid var(--1891int-line);
  white-space: nowrap;
}
.mchip::before { content: ""; width: 7px; height: 7px; border-radius: 50%; background: currentColor; opacity: .85; }
.mchip.is-open    { background:#FFF6E0; color:#7A5300; border-color:#E9D7A4; }
.mchip.is-offered { background:#EDE6F8; color:#4A2A87; border-color:#C9B8E8; }
.mchip.is-claimed { background:var(--1891int-river-tint); color:var(--1891int-river-deep); border-color:var(--1891int-river-soft); }
.mchip.is-confirmed { background:#E6F3EB; color:var(--1891int-ok); border-color:#B6DCC5; }
.mchip.is-warn    { background:var(--1891int-bloom-tint); color:var(--1891int-bloom-deep); border-color:var(--1891int-bloom-soft); }
.mchip.is-plain::before { display:none; }
.mchip.is-plain { padding-left: 10px; }

/* Rows — generic line item (board jobs, invoice lines, candidates) */
.ui-row {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 12px;
  border: 1px solid var(--1891int-line);
  border-radius: var(--1891int-radius-md);
  background: var(--1891int-paper);
  margin-top: 8px;
  font-size: 13px;
  transition: background-color 200ms var(--1891int-ease, cubic-bezier(.16,1,.3,1)),
              border-color 200ms var(--1891int-ease, cubic-bezier(.16,1,.3,1)),
              transform 200ms var(--1891int-ease, cubic-bezier(.16,1,.3,1));
}
.ui-row:hover { border-color: var(--1891int-bloom-soft); background: var(--1891int-paper-warm); transform: translateX(2px); }
.ui-row .ui-row-main { flex: 1 1 auto; min-width: 0; }
.ui-row .ui-row-title { font-weight: 700; color: var(--1891int-ink); display: block; }
.ui-row .ui-row-sub { color: var(--1891int-fog); font-size: 11.5px; display: block; margin-top: 1px; }
.ui-row .ui-row-side { flex: 0 0 auto; text-align: right; font-weight: 700; color: var(--1891int-ink); font-variant-numeric: tabular-nums; }
.ui-row.is-highlight { border-color: var(--1891int-bloom); box-shadow: 0 0 0 3px var(--1891int-bloom-tint); }

/* Score bars (smart-fill ranking) */
.ui-score { display: grid; grid-template-columns: 96px 1fr 34px; gap: 8px; align-items: center; margin-top: 7px; font-size: 12px; }
.ui-score .ui-score-lbl { color: var(--1891int-ink-soft); }
.ui-score .ui-score-track { height: 7px; border-radius: 4px; background: var(--1891int-paper-deep); overflow: hidden; }
.ui-score .ui-score-fill { height: 100%; border-radius: 4px; background: linear-gradient(90deg, var(--1891int-river), var(--1891int-bloom)); }
.ui-score .ui-score-val { text-align: right; font-weight: 700; color: var(--1891int-ink); font-variant-numeric: tabular-nums; }

/* KPI tiles + tiny bar chart (reporting) */
.ui-kpis { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
.ui-kpi { border: 1px solid var(--1891int-line); border-radius: var(--1891int-radius-md); padding: 12px; background: var(--1891int-paper-warm); }
.ui-kpi .ui-kpi-num { font-family: var(--1891int-display); font-size: 26px; font-weight: 700; line-height: 1; color: var(--1891int-bloom-deep); }
.ui-kpi .ui-kpi-lbl { font-size: 10.5px; text-transform: uppercase; letter-spacing: .06em; color: var(--1891int-fog); font-weight: 700; margin-top: 6px; }
.ui-kpi .ui-kpi-trend { font-size: 11px; color: var(--1891int-ok); font-weight: 700; }
.ui-chart { display: flex; align-items: flex-end; gap: 9px; height: 96px; margin-top: var(--1891int-s-4); padding-top: var(--1891int-s-3); border-top: 1px solid var(--1891int-line); }
.ui-chart .ui-col { flex: 1; display: flex; flex-direction: column; align-items: center; gap: 6px; height: 100%; justify-content: flex-end; }
.ui-chart .ui-col i { width: 100%; max-width: 26px; border-radius: 5px 5px 0 0; background: linear-gradient(180deg, var(--1891int-bloom), var(--1891int-bloom-deep)); display: block; transition: filter 200ms var(--1891int-ease, cubic-bezier(.16,1,.3,1)); }
.ui-chart .ui-col:nth-child(even) i { background: linear-gradient(180deg, var(--1891int-river-soft), var(--1891int-river)); }
.ui-chart .ui-col span { font-size: 10px; color: var(--1891int-fog); }
.mock:hover .ui-chart .ui-col i { filter: brightness(1.06); }

/* Caption / transcript stream (CART + VRI) */
.ui-caption { background: var(--1891int-ink); border-radius: var(--1891int-radius-md); padding: var(--1891int-s-4); }
.ui-caption .ui-cap-line { color: #E7E2D6; font-size: 13.5px; line-height: 1.5; margin: 0 0 8px; }
.ui-caption .ui-cap-line:last-child { margin-bottom: 0; }
.ui-caption .ui-cap-spk { color: var(--1891int-bloom-soft); font-weight: 700; }
.ui-caption .ui-cap-live { color: #fff; }
.ui-caption .ui-cap-live::after { content: "▍"; color: var(--1891int-bloom-soft); animation: cap-caret 1s step-end infinite; }
@keyframes cap-caret { 50% { opacity: 0; } }

/* Video tiles (VRI) */
.ui-stage { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.ui-tile { aspect-ratio: 4/3; border-radius: var(--1891int-radius-md); position: relative; overflow: hidden; display: flex; align-items: flex-end; padding: 8px; color: #fff; font-size: 11.5px; font-weight: 700; }
.ui-tile.t-a { background: radial-gradient(120% 120% at 30% 20%, #3d6f6c, #1E4544); }
.ui-tile.t-b { background: radial-gradient(120% 120% at 70% 30%, #b9614e, #7c3022); }
.ui-tile .ui-tile-tag { background: rgba(0,0,0,.34); padding: 2px 8px; border-radius: var(--1891int-radius-pill); backdrop-filter: blur(2px); }
.ui-tile::after { content: ""; position: absolute; top: 9px; right: 9px; width: 8px; height: 8px; border-radius: 50%; background: #ff5f56; box-shadow: 0 0 0 0 rgba(255,95,86,.6); animation: rec-pulse 1.8s ease-out infinite; }
@keyframes rec-pulse { 0% { box-shadow: 0 0 0 0 rgba(255,95,86,.55); } 100% { box-shadow: 0 0 0 7px rgba(255,95,86,0); } }

/* Two-pane (AI intake, translation) */
.ui-panes { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
@media (max-width: 420px) { .ui-panes { grid-template-columns: 1fr; } }
.ui-pane { border: 1px solid var(--1891int-line); border-radius: var(--1891int-radius-md); padding: 12px; background: var(--1891int-paper-warm); font-size: 12.5px; line-height: 1.5; color: var(--1891int-ink-soft); }
.ui-pane h5 { margin: 0 0 8px; font-family: var(--1891int-body); font-size: 10.5px; text-transform: uppercase; letter-spacing: .07em; color: var(--1891int-fog); }
.ui-pane.is-out { background: var(--1891int-paper); }
.ui-field { display: flex; justify-content: space-between; gap: 8px; padding: 5px 0; border-bottom: 1px dashed var(--1891int-line); }
.ui-field:last-child { border-bottom: 0; }
.ui-field .ui-field-k { color: var(--1891int-fog); }
.ui-field .ui-field-v { color: var(--1891int-ink); font-weight: 600; text-align: right; }
/* redaction marks */
.ui-redact { background: var(--1891int-ink); color: var(--1891int-ink); border-radius: 3px; padding: 0 6px; font-size: 11px; letter-spacing: 1px; user-select: none; }
.ui-token { background: var(--1891int-river-tint); color: var(--1891int-river-deep); border-radius: 3px; padding: 0 5px; font-weight: 700; font-size: 11px; }

/* Integration tiles (role-labelled, no logos) */
.ui-integ { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; }
.ui-integ .ui-itile {
  border: 1px solid var(--1891int-line); border-radius: var(--1891int-radius-md);
  padding: 12px 10px; text-align: center; background: var(--1891int-paper-warm);
  transition: transform 220ms var(--1891int-ease, cubic-bezier(.16,1,.3,1)),
              border-color 220ms var(--1891int-ease, cubic-bezier(.16,1,.3,1)),
              background-color 220ms var(--1891int-ease, cubic-bezier(.16,1,.3,1));
}
.ui-itile .ui-itile-ico { font-size: 19px; line-height: 1; }
.ui-itile .ui-itile-lbl { font-size: 11px; font-weight: 700; color: var(--1891int-ink-soft); margin-top: 6px; display: block; }
.mock:hover .ui-itile:hover { transform: translateY(-3px); border-color: var(--1891int-bloom-soft); background: var(--1891int-bloom-tint); }

/* A small "totals" footer used by invoice + payout mocks */
.ui-total { display: flex; justify-content: space-between; align-items: baseline; margin-top: var(--1891int-s-3); padding-top: var(--1891int-s-3); border-top: 2px solid var(--1891int-ink); font-weight: 700; }
.ui-total .ui-total-num { font-family: var(--1891int-display); font-size: 22px; color: var(--1891int-bloom-deep); }

/* Caption strip under any mock */
.mock-caption {
  text-align: center;
  font-size: 13px;
  color: var(--1891int-fog);
  margin-top: var(--1891int-s-3);
}
.mock-caption strong { color: var(--1891int-ink-soft); }

/* =============================================================================
   Section-heading underline reveal + link-arrow life (site-wide polish)
   ============================================================================= */
.section h2 .uline,
h2.uline {
  position: relative;
}
/* Arrows written as "→" inside links nudge on hover, everywhere */
a:hover .arrow, .lnk-arrow:hover .arrow { display: inline-block; }
.arrow { display: inline-block; transition: transform 240ms var(--1891int-ease, cubic-bezier(.16,1,.3,1)); }
a:hover .arrow { transform: translateX(4px); }

/* CTA band gets a gentle gradient drift so the footer feels alive */
.cta-band { position: relative; overflow: hidden; }

/* Audience-switch pills lift slightly on hover */
.audience-switch a { transition: background-color 200ms var(--1891int-ease, cubic-bezier(.16,1,.3,1)), color 200ms var(--1891int-ease, cubic-bezier(.16,1,.3,1)), transform 200ms var(--1891int-ease, cubic-bezier(.16,1,.3,1)); }
.audience-switch a:hover:not([aria-current="page"]) { transform: translateY(-1px); }

/* Whole-card anchor links shouldn't underline their body text — the card
   itself is the affordance, and the "→" cue carries the link signal. */
a.card, a.pillar, a.feat-card, a.showcase-tile, a.mock { text-decoration: none; }
a.card:hover, a.pillar:hover, a.feat-card:hover { text-decoration: none; }

/* Feature-index cards get a colored top-edge on hover */
.feat-card { position: relative; overflow: hidden; }
.feat-card::after {
  content: "";
  position: absolute; left: 0; top: 0; height: 3px; width: 100%;
  background: linear-gradient(90deg, var(--1891int-bloom), var(--1891int-river));
  transform: scaleX(0); transform-origin: left;
  transition: transform 320ms var(--1891int-ease, cubic-bezier(.16,1,.3,1));
}
.feat-card:hover::after { transform: scaleX(1); }

/* -----------------------------------------------------------------------------
   Reduced-motion overrides — site.css already neutralises animations/transitions,
   but we keep an explicit gate here so reveal elements still show without delay.
   ---------------------------------------------------------------------------*/
@media (prefers-reduced-motion: reduce) {
  [data-reveal] {
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
  }
  .lifecycle-chip::before,
  .pillar:hover .pillar-num,
  .brand:hover .brand-mark,
  .hero .asl-frame,
  .hero [data-float],
  .ui-caption .ui-cap-live::after,
  .ui-tile::after {
    animation: none !important;
  }
}
