/* Product mock styles — extracted so mocks.jsx stays small */
.mock {
  width: 100%; height: 100%;
  background: var(--ink-50);
  display: flex; flex-direction: column;
  position: relative;
}
.mock-chrome {
  display: flex; align-items: center; gap: 14px;
  padding: 10px 16px;
  background: var(--white);
  border-bottom: 1px solid var(--ink-150);
}
.mock-chrome .dots { display: flex; gap: 6px; }
.mock-chrome .dots span { width: 10px; height: 10px; border-radius: 50%; background: var(--ink-200); }
.mock-chrome .dots span:first-child { background: #E5675A; }
.mock-chrome .dots span:nth-child(2) { background: #E0B341; }
.mock-chrome .dots span:nth-child(3) { background: #5EB87A; }
.mock-url {
  flex: 1; text-align: center;
  font-size: 11px; color: var(--ink-500);
  font-family: var(--ff-mono);
  background: var(--ink-100);
  padding: 4px 10px; border-radius: 6px;
  max-width: 360px;
  margin: 0 auto;
}
.mock-body { flex: 1; display: flex; min-height: 0; }
.mock-body-plain { padding: 20px; flex-direction: column; gap: 14px; }
.mock-sidebar {
  width: 180px; flex-shrink: 0;
  background: var(--navy-950);
  color: rgba(255,255,255,.7);
  padding: 14px 12px;
  display: flex; flex-direction: column; gap: 4px;
  font-size: 12px;
}
.mock-brand { display: flex; align-items: center; gap: 8px; font-weight: 700; color: var(--white); font-size: 13px; padding: 6px 8px; margin-bottom: 10px; }
.mock-brand-dot { width: 14px; height: 14px; border-radius: 4px; background: linear-gradient(145deg, var(--navy-500), var(--navy-400)); }
.mock-nav { padding: 7px 10px; border-radius: 5px; color: rgba(255,255,255,.55); }
.mock-nav.active { background: rgba(255,255,255,.08); color: var(--white); }
.mock-main { flex: 1; padding: 18px; overflow: hidden; display: flex; flex-direction: column; gap: 14px; }
.mock-kpis { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; }
.mock-kpi {
  background: var(--white);
  border: 1px solid var(--ink-150);
  border-radius: 10px;
  padding: 12px 14px;
}
.mock-kpi .k { font-size: 10px; color: var(--ink-500); text-transform: uppercase; letter-spacing: .05em; font-weight: 600; }
.mock-kpi .v { font-size: 20px; font-weight: 700; color: var(--ink-900); margin-top: 4px; letter-spacing: -.01em; }
.mock-kpi .d { font-size: 11px; color: var(--success); margin-top: 2px; font-weight: 500; }
.mock-kpi .d.down { color: var(--danger); }
.mock-chart {
  background: var(--white);
  border: 1px solid var(--ink-150);
  border-radius: 10px;
  padding: 14px;
  display: flex; flex-direction: column; gap: 8px;
  flex: 1; min-height: 0;
}
.mock-chart-head { display: flex; justify-content: space-between; align-items: flex-start; }
.chart-title { font-size: 13px; font-weight: 600; color: var(--ink-900); }
.chart-sub { font-size: 10px; color: var(--ink-500); margin-top: 2px; }
.mock-pills { display: flex; gap: 4px; }
.mock-pills .pill {
  font-size: 10px; padding: 3px 8px; border-radius: 999px; background: var(--ink-100); color: var(--ink-500); font-weight: 500;
}
.mock-pills .pill.active { background: var(--navy-900); color: var(--white); }
.mock-svg { width: 100%; flex: 1; min-height: 0; }
.mock-table {
  background: var(--white);
  border: 1px solid var(--ink-150);
  border-radius: 10px;
  overflow: hidden;
  font-size: 12px;
}
.mt-row {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  padding: 9px 14px;
  border-bottom: 1px solid var(--ink-150);
  align-items: center;
}
.mt-row:last-child { border-bottom: 0; }
.mt-head { background: var(--ink-50); font-size: 10px; text-transform: uppercase; letter-spacing: .05em; font-weight: 600; color: var(--ink-500); }
.mt-debt { grid-template-columns: 1.5fr 0.6fr 1fr 1fr 0.8fr; }
.mt-row .muted { color: var(--ink-500); }
.mt-row .strong { font-weight: 600; color: var(--ink-900); }
.mt-row .stage { font-size: 11px; padding: 3px 8px; border-radius: 999px; width: fit-content; font-weight: 500; }
.s-0 { background: rgba(199,120,0,.12); color: var(--warn); }
.s-1 { background: rgba(59,99,214,.1); color: var(--navy-700); }
.s-2 { background: rgba(196,49,75,.1); color: var(--danger); }
.s-3 { background: var(--ink-100); color: var(--ink-600); }
.mt-row .action { font-size: 11px; color: var(--accent); font-weight: 500; }

.mock-header-row { display: grid; grid-template-columns: 1fr 1.4fr; gap: 12px; }
.mock-bigstat {
  background: var(--navy-950);
  color: var(--white);
  border-radius: 10px;
  padding: 18px 20px;
}
.mock-bigstat .k { font-size: 11px; text-transform: uppercase; letter-spacing: .05em; opacity: .7; font-weight: 600; }
.mock-bigstat .v { font-size: 30px; font-weight: 700; margin-top: 6px; letter-spacing: -.02em; }
.mock-bigstat .d { font-size: 12px; margin-top: 4px; color: #6EDB9A; }
.mock-bigstat .d.down { color: #FF8080; }
.mock-aging { background: var(--white); border: 1px solid var(--ink-150); border-radius: 10px; padding: 14px 16px; display: grid; gap: 8px; }
.aging-row { display: grid; grid-template-columns: 14px 1fr auto; align-items: center; gap: 10px; font-size: 12px; }
.aging-row .dot { width: 10px; height: 10px; border-radius: 2px; }
.aging-row .l { color: var(--ink-600); }
.aging-row .v { font-weight: 600; color: var(--ink-900); }

.mock-2col { display: grid; grid-template-columns: 1.4fr 1fr; gap: 14px; flex: 1; min-height: 0; }
.mock-bars { display: flex; gap: 8px; align-items: flex-end; flex: 1; padding-top: 10px; }
.mock-bars .bar { flex: 1; background: linear-gradient(to top, var(--navy-400), var(--navy-700)); border-radius: 4px 4px 0 0; min-height: 20px; }

/* Resident phone mock */
.mock-resident { background: var(--navy-100); align-items: center; justify-content: center; padding: 20px; display: flex; flex-direction: column; }
.mock-phone {
  width: 260px; aspect-ratio: 9/17;
  background: var(--ink-900);
  border-radius: 36px;
  padding: 10px;
  box-shadow: 0 20px 40px rgba(10,23,54,.25);
  position: relative;
}
.mock-phone-body {
  background: var(--ink-50);
  width: 100%; height: 100%;
  border-radius: 28px;
  padding: 28px 18px 16px;
  display: flex; flex-direction: column; gap: 12px;
  overflow: hidden;
}
.res-head { display: flex; justify-content: space-between; align-items: center; }
.res-greet { font-size: 11px; color: var(--ink-500); }
.res-name { font-size: 16px; font-weight: 700; color: var(--ink-900); }
.res-ava { width: 34px; height: 34px; border-radius: 50%; background: var(--navy-700); color: #fff; display: grid; place-items: center; font-weight: 700; font-size: 13px; }
.res-card {
  background: var(--navy-950); color: var(--white);
  border-radius: 14px; padding: 14px;
}
.res-card .k { font-size: 10px; text-transform: uppercase; letter-spacing: .05em; opacity: .7; font-weight: 600; }
.res-card .v { font-size: 22px; font-weight: 700; letter-spacing: -.01em; margin-top: 2px; }
.res-card .due { font-size: 11px; color: #FFB28A; margin-top: 2px; }
.res-card button { margin-top: 10px; width: 100%; padding: 8px; font-size: 12px; background: var(--white); color: var(--ink-900); border-radius: 8px; font-weight: 600; }
.res-bars { background: var(--white); border-radius: 12px; padding: 10px 14px; display: grid; gap: 6px; font-size: 12px; }
.rb { display: flex; justify-content: space-between; padding: 4px 0; color: var(--ink-700); border-bottom: 1px solid var(--ink-150); }
.rb:last-child { border-bottom: 0; }
.rb-v { font-weight: 600; color: var(--ink-900); }
.res-ticket { display: flex; gap: 10px; align-items: center; background: var(--white); padding: 10px 14px; border-radius: 12px; }
.rt-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--warn); box-shadow: 0 0 0 3px rgba(199,120,0,.2); }
.rt-t { font-size: 12px; font-weight: 600; color: var(--ink-900); }
.rt-s { font-size: 10px; color: var(--ink-500); }

.mock-label {
  position: absolute; bottom: 10px; right: 12px;
  font-family: var(--ff-mono);
  font-size: 10px;
  color: var(--ink-400);
  background: rgba(255,255,255,.85);
  padding: 4px 8px;
  border-radius: 4px;
  letter-spacing: .02em;
}

/* Hero B visual: reuse admin mock, scaled */
.hero-b-visual .mock { transform: none; }

@media (max-width: 600px) {
  .mock-sidebar { display: none; }
  .mock-kpis { grid-template-columns: 1fr 1fr; }
  .mt-debt { grid-template-columns: 1.3fr 0.7fr 1fr; }
  .mt-debt > span:nth-child(n+4) { display: none; }
  .mt-debt.mt-head > span:nth-child(n+4) { display: none; }
  .mock-header-row { grid-template-columns: 1fr; }
  .mock-2col { grid-template-columns: 1fr; }
}
