/* =============================================================================
   File: /var/www/html/presenze-new/assets/css/dvm-repliche-force-visible.css
   STEP113 - UI repliche visibile e diagnostica
   Scopo: rendere evidente il caricamento asset e migliorare leggibilita' operativa.
   ========================================================================== */

:root {
  --dvm-rep-force-ink: #101828;
  --dvm-rep-force-muted: #667085;
  --dvm-rep-force-border: #cbd5e1;
  --dvm-rep-force-panel: #ffffff;
  --dvm-rep-force-soft: #f8fafc;
  --dvm-rep-force-blue: #1d4ed8;
  --dvm-rep-force-blue-bg: #eff6ff;
  --dvm-rep-force-red: #991b1b;
  --dvm-rep-force-red-bg: #fff1f2;
  --dvm-rep-force-green: #166534;
  --dvm-rep-force-green-bg: #ecfdf3;
  --dvm-rep-force-amber: #92400e;
  --dvm-rep-force-amber-bg: #fffbeb;
  --dvm-rep-force-gray: #344054;
  --dvm-rep-force-gray-bg: #f2f4f7;
}

body.dvm-repliche-force-visible-ready table.dvm-repliche-force-table {
  border-collapse: separate !important;
  border-spacing: 0 .38rem !important;
  width: 100% !important;
}

body.dvm-repliche-force-visible-ready table.dvm-repliche-force-table th {
  position: sticky;
  top: 0;
  z-index: 3;
  background: #f8fafc !important;
  color: var(--dvm-rep-force-gray) !important;
  font-size: .82rem !important;
  text-transform: uppercase;
  letter-spacing: .045em;
  border-bottom: 1px solid var(--dvm-rep-force-border) !important;
}

body.dvm-repliche-force-visible-ready table.dvm-repliche-force-table td {
  vertical-align: top !important;
  padding-top: .72rem !important;
  padding-bottom: .72rem !important;
  border-top: 1px solid rgba(203, 213, 225, .85) !important;
  border-bottom: 1px solid rgba(203, 213, 225, .85) !important;
}

.dvm-repliche-force-banner,
.dvm-repliche-force-panel {
  box-sizing: border-box;
  margin: .85rem 0 1rem 0;
  padding: 1rem;
  border: 1px solid var(--dvm-rep-force-border);
  border-radius: 20px;
  background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
  color: var(--dvm-rep-force-ink);
  box-shadow: 0 14px 32px rgba(15, 23, 42, .08);
}

.dvm-repliche-force-banner {
  border-color: #93c5fd;
  background: linear-gradient(180deg, #eff6ff 0%, #ffffff 100%);
}

.dvm-repliche-force-banner strong {
  display: block;
  font-size: 1.08rem;
  font-weight: 950;
  letter-spacing: -.01em;
}

.dvm-repliche-force-banner span {
  display: block;
  margin-top: .25rem;
  color: var(--dvm-rep-force-muted);
  font-size: .92rem;
  line-height: 1.35;
}

.dvm-repliche-force-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: .75rem;
  margin: .85rem 0;
}

.dvm-repliche-force-kpi {
  padding: .85rem;
  min-height: 82px;
  border: 1px solid var(--dvm-rep-force-border);
  border-radius: 17px;
  background: var(--dvm-rep-force-panel);
}

.dvm-repliche-force-kpi small {
  display: block;
  color: var(--dvm-rep-force-muted);
  font-size: .76rem;
  font-weight: 850;
  letter-spacing: .045em;
  text-transform: uppercase;
}

.dvm-repliche-force-kpi b {
  display: block;
  margin-top: .15rem;
  font-size: 1.85rem;
  line-height: 1;
  font-weight: 950;
}

.dvm-repliche-force-kpi--bad { background: var(--dvm-rep-force-red-bg); border-color: #fda4af; color: var(--dvm-rep-force-red); }
.dvm-repliche-force-kpi--ok { background: var(--dvm-rep-force-green-bg); border-color: #86efac; color: var(--dvm-rep-force-green); }
.dvm-repliche-force-kpi--warn { background: var(--dvm-rep-force-amber-bg); border-color: #fcd34d; color: var(--dvm-rep-force-amber); }
.dvm-repliche-force-kpi--off { background: var(--dvm-rep-force-gray-bg); border-color: #d0d5dd; color: var(--dvm-rep-force-gray); }

.dvm-repliche-force-actions {
  display: flex;
  flex-wrap: wrap;
  gap: .55rem;
  align-items: center;
  margin-top: .75rem;
}

.dvm-repliche-force-actions button,
.dvm-repliche-force-actions input {
  min-height: 40px;
  border: 1px solid var(--dvm-rep-force-border);
  border-radius: 999px;
  padding: .48rem .78rem;
  font-weight: 800;
  background: #fff;
  color: var(--dvm-rep-force-ink);
}

.dvm-repliche-force-actions input {
  min-width: min(360px, 100%);
  font-weight: 650;
}

.dvm-repliche-force-actions button.is-active {
  color: #fff;
  background: var(--dvm-rep-force-blue);
  border-color: var(--dvm-rep-force-blue);
}

.dvm-repliche-force-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 74px;
  padding: .24rem .55rem;
  border-radius: 999px;
  font-size: .76rem;
  font-weight: 950;
  letter-spacing: .035em;
}

.dvm-repliche-force-pill--error { color: var(--dvm-rep-force-red); background: var(--dvm-rep-force-red-bg); border: 1px solid #fda4af; }
.dvm-repliche-force-pill--ok { color: var(--dvm-rep-force-green); background: var(--dvm-rep-force-green-bg); border: 1px solid #86efac; }
.dvm-repliche-force-pill--warn { color: var(--dvm-rep-force-amber); background: var(--dvm-rep-force-amber-bg); border: 1px solid #fcd34d; }
.dvm-repliche-force-pill--off { color: var(--dvm-rep-force-gray); background: var(--dvm-rep-force-gray-bg); border: 1px solid #d0d5dd; }

tr.dvm-repliche-force-row-error > td { background: var(--dvm-rep-force-red-bg) !important; }
tr.dvm-repliche-force-row-warn > td { background: var(--dvm-rep-force-amber-bg) !important; }
tr.dvm-repliche-force-row-ok > td { background: #fbfffc !important; }
tr.dvm-repliche-force-row-off > td { background: #f9fafb !important; color: #667085 !important; }

body.dvm-repliche-force-hide-ok tr.dvm-repliche-force-row-ok,
body.dvm-repliche-force-errors-only tr:not(.dvm-repliche-force-row-error),
tr.dvm-repliche-force-search-hidden {
  display: none !important;
}

.dvm-repliche-force-message {
  max-width: 680px;
  white-space: normal !important;
  line-height: 1.35;
  font-weight: 750;
}

@media (max-width: 1000px) {
  .dvm-repliche-force-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 640px) {
  .dvm-repliche-force-grid { grid-template-columns: 1fr; }
  .dvm-repliche-force-actions button,
  .dvm-repliche-force-actions input { width: 100%; }
}
