/* ═══════════════════════════════════════════
   TOKENS
═══════════════════════════════════════════ */
:root {
  --bg: #f8fafc;
  --bg2: #f1f5f9;
  --surface: #ffffff;
  --surface2: #f8fafc;
  --border: rgba(0, 0, 0, .06);
  --border2: rgba(0, 0, 0, .1);

  --em: #00c587;
  --em2: #0097b2;
  --em-glow: rgba(0, 197, 135, .14);
  --em-dim: rgba(0, 197, 135, .09);

  --amber: #d97706;
  --amber-dim: rgba(217, 119, 6, .1);

  --blue: #2563eb;
  --blue-dim: rgba(37, 99, 235, .08);

  --red: #dc2626;
  --red-dim: rgba(220, 38, 38, .08);

  --purple: #7c3aed;
  --purple-dim: rgba(124, 58, 237, .08);

  --text: #0f172a;
  --text2: #475569;
  --text3: #64748b;

  --font-head: 'Instrument Serif', Georgia, serif;
  --font-body: 'Space Grotesk', sans-serif;
  --font-mono: 'JetBrains Mono', monospace;

  --r-sm: 8px;
  --r-md: 14px;
  --r-lg: 20px;
  --r-xl: 28px;

  --shadow-em: 0 4px 20px rgba(5, 150, 105, .12);
  --shadow-card: 0 4px 12px rgba(0, 0, 0, .05), 0 1px 2px rgba(0, 0, 0, .02);
}

/* ═══════════════════════════════════════════
   RESET & BASE
═══════════════════════════════════════════ */
*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  overflow-x: hidden;
  max-width: 100%;
}

body {
  background: var(--bg);
  color: var(--text);
  font-family: var(--font-body);
  min-height: 100vh;
  overflow-x: hidden;
  max-width: 100%;
}

/* Mesh background */
body::before {
  content: '';
  position: fixed;
  inset: 0;
  background:
    radial-gradient(ellipse 80% 50% at 10% 0%, rgba(0, 229, 160, .06) 0%, transparent 60%),
    radial-gradient(ellipse 60% 40% at 90% 100%, rgba(59, 158, 255, .05) 0%, transparent 60%),
    radial-gradient(ellipse 40% 30% at 50% 50%, rgba(245, 166, 35, .03) 0%, transparent 60%);
  pointer-events: none;
  z-index: 0;
}

body>* {
  position: relative;
  z-index: 1;
}

/* ═══════════════════════════════════════════
   LOCK SCREEN
═══════════════════════════════════════════ */
.lock-overlay {
  position: fixed;
  inset: 0;
  z-index: 900;
  background: rgba(5, 12, 24, .97);
  backdrop-filter: blur(20px);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: opacity .4s, visibility .4s;
}

.lock-overlay.hidden {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}

.lock-card {
  background: var(--surface);
  border: 1px solid var(--border2);
  border-radius: var(--r-xl);
  padding: 48px 52px;
  text-align: center;
  max-width: 400px;
  width: 92%;
  box-shadow: var(--shadow-em);
  animation: lockIn .5s cubic-bezier(.16, 1, .3, 1);
}

@keyframes lockIn {
  from {
    opacity: 0;
    transform: scale(.92) translateY(20px);
  }

  to {
    opacity: 1;
    transform: scale(1) translateY(0);
  }
}

.lock-icon-wrap {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background: var(--em-dim);
  border: 1px solid rgba(0, 229, 160, .3);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 20px;
  font-size: 28px;
}

.lock-card h2 {
  font-family: var(--font-head);
  font-size: 1.6rem;
  font-style: italic;
  margin-bottom: 6px;
}

.lock-card p {
  color: var(--text2);
  font-size: .88rem;
  margin-bottom: 28px;
  line-height: 1.5;
}

.lock-input {
  width: 100%;
  background: var(--surface2);
  border: 1px solid var(--border2);
  color: var(--text);
  padding: 14px 18px;
  border-radius: var(--r-md);
  font-size: 1.1rem;
  text-align: center;
  letter-spacing: .4em;
  font-family: var(--font-mono);
  margin-bottom: 14px;
  transition: border-color .2s, box-shadow .2s;
}

.lock-input:focus {
  outline: none;
  border-color: var(--em);
  box-shadow: 0 0 0 3px var(--em-dim);
}

.lock-btn {
  width: 100%;
  background: var(--em);
  color: #021a0e;
  border: none;
  padding: 14px;
  border-radius: var(--r-md);
  font-family: var(--font-body);
  font-weight: 700;
  font-size: .95rem;
  cursor: pointer;
  letter-spacing: .03em;
  transition: opacity .2s, transform .1s;
}

.lock-btn:hover {
  opacity: .88;
}

.lock-btn:active {
  transform: scale(.98);
}

.lock-forgot-btn {
  width: 100%;
  background: transparent;
  color: var(--text3);
  border: none;
  padding: 10px;
  font-family: var(--font-body);
  font-size: .82rem;
  cursor: pointer;
  text-decoration: underline;
  margin-top: 4px;
  transition: color .2s;
}
.lock-forgot-btn:hover { color: var(--em); }

.lock-err {
  color: var(--red);
  font-size: .82rem;
  margin-top: 10px;
  min-height: 18px;
}

.lock-form-group {
  text-align: left;
  margin-bottom: 12px;
}

.lock-form-group label {
  display: block;
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--text3);
  text-transform: uppercase;
  margin-bottom: 6px;
  letter-spacing: 0.05em;
}

.lock-input.login-input {
  letter-spacing: normal;
  font-family: var(--font-body);
  text-align: left;
  font-size: 0.95rem;
  padding: 12px 14px;
}

.pass-wrap {
  position: relative;
}

.pass-eye {
  position: absolute;
  right: 12px;
  top: 50%;
  transform: translateY(-50%);
  cursor: pointer;
  color: var(--text3);
  font-size: 1.15rem;
  user-select: none;
  padding: 4px;
  line-height: 1;
}

/* ═══════════════════════════════════════════
   HEADER
═══════════════════════════════════════════ */
.header {
  position: sticky;
  top: 0;
  z-index: 200;
  background: linear-gradient(to right, rgba(11, 29, 53, 0.97), rgba(13, 56, 88, 0.97));
  backdrop-filter: blur(20px);
  border-bottom: 1px solid rgba(0, 197, 135, 0.12);
  padding: 0 28px;
  display: flex;
  align-items: center;
  gap: 16px;
  height: 60px;
  max-width: 100%;
  overflow: hidden;
  box-sizing: border-box;
}

.logo-mark {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-shrink: 0;
}

.logo-icon {
  width: 36px;
  height: 36px;
  background: rgba(255, 255, 255, 0.07);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  box-shadow: 0 4px 14px rgba(0, 0, 0, 0.3), 0 0 16px var(--em-glow);
  overflow: hidden;
  padding: 4px;
}

.logo-text {
  font-size: .92rem;
  font-weight: 700;
  letter-spacing: -.02em;
  color: rgba(255, 255, 255, 0.92);
}

.logo-text span {
  color: var(--em);
}

.logo-sub {
  font-size: .585rem;
  color: rgba(255, 255, 255, 0.38);
  display: block;
  letter-spacing: .06em;
  text-transform: uppercase;
  margin-top: 1px;
}

.nav {
  display: flex;
  gap: 2px;
  flex: 1;
  justify-content: center;
  flex-wrap: wrap;
}

.nav-btn {
  padding: 6px 16px;
  border: none;
  border-radius: var(--r-sm);
  background: transparent;
  color: rgba(255, 255, 255, 0.55);
  font-family: var(--font-body);
  font-size: .78rem;
  font-weight: 600;
  cursor: pointer;
  transition: all .2s;
  white-space: nowrap;
}

.nav-btn:hover {
  color: rgba(255, 255, 255, 0.88);
  background: rgba(255, 255, 255, .06);
}

.nav-btn.active {
  background: rgba(0, 197, 135, 0.12);
  color: #00e5a0;
}

/* Badge de dias faltantes no nav (B5) */
.nav-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--red, #ff4d6a);
  color: #fff;
  border-radius: 9px;
  font-size: .65rem;
  font-weight: 700;
  min-width: 16px;
  height: 16px;
  padding: 0 4px;
  margin-left: 5px;
  vertical-align: middle;
  line-height: 1;
}

.header-right {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-shrink: 1;
  min-width: 0;
}

.date-chip {
  padding: 5px 12px;
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.10);
  font-size: .72rem;
  font-weight: 600;
  color: rgba(255, 255, 255, 0.80);
  font-family: var(--font-mono);
}

.sb-pill {
  padding: 4px 11px;
  border-radius: 20px;
  font-size: .7rem;
  font-weight: 700;
  background: rgba(255, 255, 255, 0.07);
  color: rgba(255, 255, 255, 0.40);
  transition: all .4s;
  display: inline-flex;
  align-items: center;
  gap: 5px;
}

.sb-pill::before {
  content: '';
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--text3);
}

.sb-pill.ok {
  background: var(--em-dim);
  color: var(--em);
}

.sb-pill.ok::before {
  background: var(--em);
  box-shadow: 0 0 8px var(--em);
}

.sb-pill.err {
  background: var(--red-dim);
  color: var(--red);
}

.sb-pill.err::before {
  background: var(--red);
  box-shadow: 0 0 8px var(--red);
}

/* ═══════════════════════════════════════════
   LAYOUT / VIEWS
═══════════════════════════════════════════ */
.view {
  display: none;
  padding: 28px;
  max-width: 1440px;
  margin: 0 auto;
  overflow-x: hidden;
  box-sizing: border-box;
  width: 100%;
}

.view.active {
  display: block;
  animation: fadeUp .35s cubic-bezier(.16, 1, .3, 1);
}

@keyframes fadeUp {
  from {
    opacity: 0;
    transform: translateY(12px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* ═══════════════════════════════════════════
   PAGE HEADER
═══════════════════════════════════════════ */
.page-hdr {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 24px;
  flex-wrap: wrap;
  max-width: 100%;
}

.page-hdr h2 {
  font-family: var(--font-head);
  font-size: 1.75rem;
  font-style: italic;
  letter-spacing: -.02em;
  flex: 1;
}

.page-hdr h2 em {
  color: var(--em);
  font-style: italic;
}

/* ═══════════════════════════════════════════
   SELECT / CONTROLS
═══════════════════════════════════════════ */
.sel {
  background: var(--surface2);
  border: 1px solid var(--border2);
  color: var(--text);
  padding: 8px 14px;
  border-radius: var(--r-sm);
  font-family: var(--font-body);
  font-size: .82rem;
  cursor: pointer;
  transition: border-color .2s;
}

.sel:focus {
  outline: none;
  border-color: var(--em);
}

.uti-wrap {
  position: relative;
}

.uti-sel {
  background: var(--surface2);
  border: 1px solid var(--em);
  color: var(--text);
  padding: 8px 36px 8px 14px;
  border-radius: var(--r-sm);
  font-family: var(--font-body);
  font-size: .82rem;
  cursor: pointer;
  min-width: 180px;
  appearance: none;
  transition: box-shadow .2s;
}

.uti-sel:focus {
  outline: none;
  box-shadow: 0 0 0 3px var(--em-dim);
}

/* Seletor de hospital travado (role hospital — não pode trocar de hospital) */
.uti-sel:disabled {
  cursor: default;
  pointer-events: none;
  opacity: 0.85;
  border-color: transparent;
  background: var(--surface2);
}
.uti-wrap.hosp-locked .uti-arrow {
  display: none;
}

.uti-arrow {
  position: absolute;
  right: 11px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--em);
  pointer-events: none;
  font-size: .75rem;
}

.btn-primary {
  background: var(--em);
  color: #021a0e;
  border: none;
  padding: 9px 22px;
  border-radius: var(--r-sm);
  font-family: var(--font-body);
  font-weight: 700;
  font-size: .82rem;
  cursor: pointer;
  transition: opacity .2s, transform .1s;
  white-space: nowrap;
}

.btn-primary:hover {
  opacity: .88;
}

.btn-primary:active {
  transform: scale(.97);
}

.btn-save-action {
  background: #00e5a0;
  color: #032115;
  font-weight: 800;
  font-size: .88rem;
  border: 2px solid rgba(255, 255, 255, 0.2);
  box-shadow: 0 0 16px rgba(0, 229, 160, 0.5) !important;
  letter-spacing: 0.03em;
}

.btn-save-action:hover:not(:disabled) {
  background: #fff;
  color: #000;
  box-shadow: 0 0 24px rgba(0, 229, 160, 0.8) !important;
  transform: scale(1.02);
}

.btn-save-action:disabled {
  background: var(--red-dim);
  color: var(--red);
  border-color: rgba(220, 38, 38, 0.3);
  box-shadow: none !important;
  cursor: not-allowed;
  opacity: 0.8;
  transform: none;
}

.btn-ghost {
  background: var(--surface2);
  border: 1px solid var(--border2);
  color: var(--text2);
  padding: 8px 16px;
  border-radius: var(--r-sm);
  font-family: var(--font-body);
  font-weight: 600;
  font-size: .78rem;
  cursor: pointer;
  transition: all .2s;
}

.btn-ghost:hover {
  border-color: var(--em);
  color: var(--em);
}

.btn-danger {
  background: var(--red-dim);
  border: 1px solid rgba(255, 77, 106, .3);
  color: var(--red);
  padding: 8px 16px;
  border-radius: var(--r-sm);
  font-family: var(--font-body);
  font-weight: 600;
  font-size: .78rem;
  cursor: pointer;
  transition: all .2s;
}

.btn-danger:hover {
  background: rgba(255, 77, 106, .22);
}

/* ═══════════════════════════════════════════
   FORM GROUPS
═══════════════════════════════════════════ */
.groups {
  display: grid;
  gap: 16px;
}

.gcard {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  overflow: hidden;
  transition: border-color .3s;
}

.gcard:hover {
  border-color: var(--border2);
}

.gtitle {
  padding: 12px 20px;
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  border-bottom: 1px solid var(--border);
  cursor: pointer;
  user-select: none;
  transition: background .2s;
}

.gtitle:hover {
  background: rgba(255, 255, 255, .02);
}

.gtitle .gtitle-arrow {
  margin-left: auto;
  font-size: .65rem;
  transition: transform .3s;
  color: var(--text3);
}

.gcard.collapsed .gtitle-arrow {
  transform: rotate(-90deg);
}

.gcard.collapsed .gcard-body {
  display: none;
}

.gcard.g-census .gtitle {
  color: var(--em);
  background: var(--em-dim);
}

.gcard.g-vm .gtitle {
  color: var(--blue);
  background: var(--blue-dim);
}

.gcard.g-mob .gtitle {
  color: var(--purple);
  background: var(--purple-dim);
}

.gcard.g-events .gtitle {
  color: var(--red);
  background: var(--red-dim);
}

.gcard.g-quality .gtitle {
  color: var(--amber);
  background: var(--amber-dim);
}

/* Via aérea row */
.va-row {
  padding: 14px 20px;
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  border-bottom: 1px solid var(--border);
  background: rgba(59, 158, 255, .04);
}

.va-label {
  font-size: .7rem;
  font-weight: 600;
  color: var(--text2);
  text-transform: uppercase;
  letter-spacing: .06em;
  white-space: nowrap;
}

.va-btns {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

.va-btn {
  padding: 5px 13px;
  border-radius: 20px;
  border: 1px solid var(--border2);
  background: transparent;
  color: var(--text2);
  font-size: .76rem;
  font-family: var(--font-body);
  font-weight: 600;
  cursor: pointer;
  transition: all .2s;
}

.va-btn:hover {
  border-color: var(--blue);
  color: var(--blue);
}

.va-btn.active {
  background: var(--blue-dim);
  border-color: var(--blue);
  color: var(--blue);
}

/* Field grid */
.fgrid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
  gap: 1px;
  background: var(--border);
  max-width: 100%;
  overflow-x: auto;
}

.fcell {
  background: var(--surface);
  padding: 13px 15px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  transition: background .2s;
}

.fcell:hover {
  background: rgba(255, 255, 255, .015);
}

.fcell label {
  font-size: .65rem;
  color: var(--text3);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .05em;
  line-height: 1.35;
}

.stepper {
  display: flex;
  align-items: center;
  gap: 5px;
}

.sbtn {
  width: 30px;
  height: 30px;
  border-radius: var(--r-sm);
  border: 1px solid var(--border2);
  background: var(--surface2);
  color: var(--text2);
  cursor: pointer;
  font-size: 1.1rem;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  font-weight: 700;
  transition: all .15s;
  touch-action: manipulation;
}

.sbtn:hover {
  background: var(--em-dim);
  border-color: var(--em);
  color: var(--em);
}

.sbtn:active {
  transform: scale(.9);
}

.sval {
  flex: 1;
  text-align: center;
  font-family: var(--font-mono);
  font-size: 1.1rem;
  font-weight: 500;
  color: var(--text);
  background: var(--surface2);
  border: 1px solid var(--border2);
  border-radius: var(--r-sm);
  padding: 4px 2px;
  cursor: pointer;
  transition: all .15s;
  min-width: 38px;
}

.sval:hover {
  border-color: var(--em);
  color: var(--em);
}

.sval[contenteditable="true"] {
  border-color: var(--em);
  background: var(--em-dim);
  color: var(--em);
  outline: none;
}

/* VM Calc display */
.vm-calc {
  padding: 10px 20px;
  background: rgba(59, 158, 255, .06);
  border-top: 1px solid var(--border);
  font-size: .78rem;
  color: var(--blue);
  font-family: var(--font-mono);
  display: flex;
  align-items: center;
  gap: 8px;
}

.vm-calc span {
  color: var(--text2);
}

/* JH section inside mob group */
.jh-header {
  padding: 10px 20px;
  font-size: .7rem;
  font-weight: 700;
  color: var(--purple);
  letter-spacing: .08em;
  text-transform: uppercase;
  background: rgba(167, 139, 250, .05);
  border-top: 1px solid var(--border);
  display: flex;
  align-items: center;
  gap: 8px;
}

/* ═══════════════════════════════════════════════════
   MAPA DE MOBILIZAÇÃO — Premium
   ═══════════════════════════════════════════════════ */

.mapa-resumo {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  padding: 10px 20px;
  background: rgba(167, 139, 250, .04);
  border-top: 1px solid var(--border);
  font-size: .72rem;
  color: var(--text2);
}
.mapa-resumo span {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 10px;
  background: var(--surface2);
  border-radius: var(--r-sm);
  border: 1px solid var(--border);
}

.mapa-leitos-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 1px;
  background: var(--border);
  border-top: 1px solid var(--border);
}

.leito-card {
  background: var(--surface);
  padding: 12px 14px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  transition: background .2s, border-color .2s;
  position: relative;
  overflow: hidden;
  min-width: 0;
}
.leito-card.leito-vazio {
  opacity: .55;
}
.leito-card.leito-pendente {
  background: rgba(245, 166, 35, .04);
}
.leito-card.leito-confirmado {
  background: rgba(0, 229, 160, .03);
}

.leito-hdr {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 6px;
}
.leito-nome {
  font-size: .72rem;
  font-weight: 700;
  color: var(--text);
  text-transform: uppercase;
  letter-spacing: .04em;
}
.leito-badge {
  font-size: .58rem;
  font-weight: 600;
  padding: 2px 8px;
  border-radius: 20px;
  letter-spacing: .04em;
}
.leito-badge-vazio {
  background: var(--surface2);
  color: var(--text3);
  border: 1px solid var(--border);
}
.leito-badge-pendente {
  background: rgba(245, 166, 35, .15);
  color: var(--amber);
  border: 1px solid rgba(245, 166, 35, .3);
}
.leito-badge-ok {
  background: rgba(0, 229, 160, .1);
  color: var(--green);
  border: 1px solid rgba(0, 229, 160, .25);
}

.leito-info {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.leito-id-row, .leito-base-row {
  display: flex;
  align-items: center;
  gap: 6px;
}
.leito-label {
  font-size: .62rem;
  color: var(--text3);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .04em;
  flex-shrink: 0;
}
.leito-id-val {
  font-family: var(--font-mono);
  font-size: .82rem;
  font-weight: 600;
  color: var(--em);
}
.leito-base-val {
  font-family: var(--font-mono);
  font-size: .82rem;
  font-weight: 500;
  color: var(--purple);
}
.leito-btn-sm {
  font-size: .58rem;
  padding: 2px 8px;
  border-radius: var(--r-sm);
  border: 1px solid var(--border2);
  background: var(--surface2);
  color: var(--text2);
  cursor: pointer;
  transition: all .15s;
}
.leito-btn-sm:hover {
  background: var(--em-dim);
  color: var(--em);
  border-color: var(--em);
}

.leito-jh-row {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}
.leito-jh-stepper {
  display: flex;
  align-items: center;
  gap: 4px;
  flex-shrink: 0;
}
.leito-jh-stepper .sbtn { width: 26px; height: 26px; font-size: .9rem; }
.leito-jh-stepper .sval { min-width: 32px; font-size: .95rem; padding: 3px 2px; }

.leito-gap {
  font-size: .62rem;
  font-weight: 700;
  text-align: center;
  padding: 3px 8px;
  border-radius: var(--r-sm);
  letter-spacing: .04em;
}
.gap-ok {
  background: rgba(0, 229, 160, .1);
  color: var(--green);
}
.gap-moderado {
  background: rgba(245, 166, 35, .12);
  color: var(--amber);
}
.gap-critico {
  background: rgba(255, 77, 106, .12);
  color: var(--red);
}

/* ── Pill buttons: via aérea + suporte respiratório ── */
.leito-resp-row {
  display: flex;
  flex-direction: column;
  gap: 3px;
  margin: 5px 0 2px;
}
.leito-resp-group {
  display: flex;
  align-items: center;
  gap: 3px;
  flex-wrap: wrap;
}
.leito-resp-label {
  font-size: .58rem;
  font-weight: 600;
  color: var(--text3);
  text-transform: uppercase;
  letter-spacing: .03em;
  min-width: 28px;
}
.resp-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 2px 7px;
  font-size: .6rem;
  font-weight: 600;
  border: 1.5px solid var(--brd);
  border-radius: 10px;
  background: var(--bg);
  color: var(--text3);
  cursor: pointer;
  transition: all .15s;
  line-height: 1.3;
  min-height: 20px;
}
.resp-pill:hover { border-color: var(--em); color: var(--em); }
.resp-pill.rp-active {
  background: var(--em);
  color: #fff;
  border-color: var(--em);
}
.resp-pill.rp-active[data-val="VM"] { background: #e74c3c; border-color: #e74c3c; }
.resp-pill.rp-active[data-val="VNI"] { background: #f39c12; border-color: #f39c12; }
.resp-pill.rp-active[data-val="OAF"] { background: #3498db; border-color: #3498db; }
.resp-pill.rp-active[data-val="O2"] { background: #1abc9c; border-color: #1abc9c; }
.resp-pill.rp-active[data-val="AA"] { background: #95a5a6; border-color: #95a5a6; }
.resp-pill.rp-active[data-val="TOT"] { background: #e67e22; border-color: #e67e22; }
.resp-pill.rp-active[data-val="TQT"] { background: #9b59b6; border-color: #9b59b6; }

/* TRE chips — eventos ventilatórios por paciente/dia */
.leito-tre-row {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-top: 5px;
  padding: 4px 2px;
  border-top: 1px dashed #e0e0e0;
}
.tre-chip {
  padding: 3px 10px;
  border: 1.5px solid #bbb;
  border-radius: 20px;
  background: #f5f5f5;
  color: #666;
  font-size: .75rem;
  font-weight: 600;
  cursor: pointer;
  transition: background .15s, border-color .15s, color .15s;
}
.tre-chip:hover:not(:disabled) { border-color: #2980b9; color: #2980b9; background: #eaf4fb; }
.tre-chip.tre-on {
  background: #2980b9;
  border-color: #2980b9;
  color: #fff;
}
.tre-suc-chip.tre-suc-on {
  background: #27ae60;
  border-color: #27ae60;
  color: #fff;
}
.tre-chip:disabled {
  opacity: .45;
  cursor: not-allowed;
}

/* N/A = paciente não atendido no dia (JH 0 válido) */
.jh-na {
  color: #95a5a6 !important;
  font-size: .68rem !important;
  font-style: italic;
}

/* Campo do censo bloqueado por auto-sync do mapa (visual como "Não Atendidos") */
.fcell-auto {
  background: rgba(39, 174, 96, 0.07);
  border-color: rgba(39, 174, 96, 0.3) !important;
  border-radius: 6px;
}
.fcell-auto label { color: #27ae60; font-weight: 600; }
.fcell-auto .sval { color: #27ae60; }
.fcell-auto .sbtn { display: none !important; }
/* Re-declara apos bloco mobile para garantir especificidade */
.fcell.fcell-auto .sbtn,
.fcell.fcell-auto .sbtn:hover,
.fcell.fcell-auto .sbtn:active { display: none !important; width: 0 !important; padding: 0 !important; margin: 0 !important; border: none !important; }

/* Auto-badge nos campos do censo preenchidos pelo mapa */
.auto-badge {
  display: inline-block;
  font-size: .5rem;
  font-weight: 600;
  color: var(--em);
  background: rgba(0, 229, 160, .1);
  padding: 1px 5px;
  border-radius: 6px;
  margin-left: 4px;
  vertical-align: middle;
  letter-spacing: .02em;
}

/* ═══════════════════════════════════════════
   MODAL DE TROCA DE PACIENTE (lf-* = leitos-fluxo)
   Separação temporal: evento durante/antes do plantão
═══════════════════════════════════════════ */
.lf-sec { margin-bottom: 14px; }
.lf-divider { border: none; border-top: 1px solid var(--border2); margin: 16px 0; }
.lf-lbl { font-size: .82rem; font-weight: 600; color: var(--text2); margin-bottom: 6px; text-transform: uppercase; letter-spacing: .04em; }
.lf-mt { margin-top: 14px; }
.lf-radios { display: flex; flex-direction: column; gap: 6px; }
.lf-radios label { display: flex; align-items: flex-start; gap: 7px; font-size: .88rem; cursor: pointer; }
.lf-radios input[type="radio"] { margin-top: 2px; flex-shrink: 0; accent-color: var(--em); }
.lf-radio-block { background: rgba(255,255,255,.03); border: 1px solid var(--border2); border-radius: 6px; padding: 7px 10px !important; transition: border-color .15s; }
.lf-radio-block:has(input:checked) { border-color: var(--em); background: rgba(0,229,160,.06); }
.lf-hint { font-style: italic; color: var(--text2); font-size: .78rem; margin-left: 4px; }
.lf-input {
  width: 100%; box-sizing: border-box;
  background: var(--surface2); border: 1px solid var(--border2);
  color: var(--text); border-radius: 6px;
  padding: 8px 12px; font-size: .9rem;
  outline: none; transition: border-color .15s;
}
.lf-input:focus { border-color: var(--em); }

.leito-acoes {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  margin-top: 4px;
}
.leito-vazio-acoes {
  display: flex;
  justify-content: center;
  padding: 8px 0;
}
.leito-btn {
  font-size: .62rem;
  font-weight: 600;
  padding: 5px 10px;
  border-radius: var(--r-sm);
  border: 1px solid var(--border2);
  background: var(--surface2);
  color: var(--text2);
  cursor: pointer;
  transition: all .15s;
  white-space: nowrap;
}
.leito-btn:hover {
  transform: translateY(-1px);
}
.leito-btn-mesmo {
  background: rgba(0, 229, 160, .1);
  color: var(--green);
  border-color: rgba(0, 229, 160, .3);
}
.leito-btn-mesmo:hover {
  background: rgba(0, 229, 160, .2);
}
.leito-btn-novo {
  background: rgba(59, 158, 255, .1);
  color: var(--blue);
  border-color: rgba(59, 158, 255, .3);
}
.leito-btn-novo:hover {
  background: rgba(59, 158, 255, .2);
}
.leito-btn-vazio {
  background: var(--surface2);
  color: var(--text3);
}
.leito-btn-alta {
  background: rgba(245, 166, 35, .1);
  color: var(--amber);
  border-color: rgba(245, 166, 35, .3);
}
.leito-btn-alta:hover {
  background: rgba(245, 166, 35, .2);
}
.leito-btn-transf {
  background: rgba(167, 139, 250, .1);
  color: var(--purple);
  border-color: rgba(167, 139, 250, .3);
}
.leito-btn-transf:hover {
  background: rgba(167, 139, 250, .2);
}
.leito-btn-obito {
  background: rgba(100, 100, 100, .08);
  color: #555;
  border-color: rgba(100, 100, 100, .25);
}
.leito-btn-obito:hover {
  background: rgba(100, 100, 100, .18);
}
.leito-btn-mover {
  background: rgba(59, 130, 246, .08);
  color: var(--blue, #3b82f6);
  border-color: rgba(59, 130, 246, .25);
}
.leito-btn-mover:hover {
  background: rgba(59, 130, 246, .18);
}
.leito-btn-excluir {
  background: rgba(255, 77, 106, .08);
  color: var(--red);
  border-color: rgba(255, 77, 106, .25);
}
.leito-btn-excluir:hover {
  background: rgba(255, 77, 106, .18);
}

/* ─── Modal Excluir/Editar paciente (xe-*) ───────────────────────────────── */
.xe-modal {
  width: min(500px, 95vw);
}
.xe-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 16px;
  font-size: .95rem;
}
.xe-close {
  padding: 2px 10px;
  font-size: 1rem;
}
.xe-sub {
  margin: 0 0 14px;
  color: var(--text-muted);
  font-size: .88rem;
}
.xe-choices {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.xe-choice-btn {
  justify-content: flex-start;
  gap: 10px;
  text-align: left;
  line-height: 1.45;
  white-space: normal;
}
.xe-choice-del {
  background: rgba(220, 53, 69, .08);
  color: var(--red);
  border-color: rgba(220, 53, 69, .3);
}
.xe-choice-del:hover {
  background: rgba(220, 53, 69, .16);
}
.xe-hint {
  font-weight: 400;
  font-size: .82rem;
  opacity: .75;
  display: block;
}
.xe-fields {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 4px;
}
.xe-field {
  flex: 1;
  min-width: 130px;
}
.xe-jh-row {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 6px;
}
.xe-jh-val {
  min-width: 28px;
  text-align: center;
  font-weight: 700;
  font-size: 1rem;
}
.xe-actions {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  margin-top: 18px;
}
.xe-del-warn {
  background: rgba(220, 53, 69, .07);
  border: 1px solid rgba(220, 53, 69, .3);
  border-radius: 8px;
  padding: 14px;
  margin-bottom: 16px;
}
.xe-del-title {
  font-weight: 700;
  color: var(--red);
  margin-bottom: 8px;
}
.xe-del-body {
  font-size: .87rem;
  line-height: 1.6;
}
.xe-del-btn {
  background: var(--red);
  color: #fff;
  border-color: var(--red);
}
.xe-del-btn:hover {
  background: #c0392b;
  border-color: #c0392b;
}

/* ─── Card clicável (kcard-clickable) ───────────────────────────────────── */
.kcard-clickable {
  cursor: pointer;
  transition: transform .12s, box-shadow .12s;
}
.kcard-clickable:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 18px rgba(0,0,0,.18);
}

/* ─── Modal de Gestão de Indefinidos (gi-*) ─────────────────────────────── */
.gi-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  background: var(--surface2, rgba(255,255,255,.04));
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 10px 12px;
  flex-wrap: wrap;
  transition: opacity .2s;
}
.gi-info {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 6px;
  flex: 1;
  min-width: 0;
}
.gi-leito {
  font-weight: 700;
  font-size: .85rem;
  color: var(--em);
  min-width: 36px;
}
.gi-nome {
  font-size: .9rem;
  font-weight: 600;
}
.gi-data {
  font-size: .78rem;
  color: var(--text-muted);
}
.gi-uti {
  font-size: .72rem;
  background: rgba(59,158,255,.1);
  color: var(--blue);
  border-radius: 4px;
  padding: 1px 6px;
}
.gi-btns {
  display: flex;
  gap: 6px;
  flex-shrink: 0;
}
.gi-btn {
  padding: 5px 10px;
  border-radius: 6px;
  font-size: .78rem;
  font-weight: 600;
  border: 1px solid transparent;
  cursor: pointer;
  transition: background .15s;
}
.gi-alta  { background: rgba(39,174,96,.1);  color: #27ae60; border-color: rgba(39,174,96,.3); }
.gi-alta:hover  { background: rgba(39,174,96,.2); }
.gi-obito { background: rgba(113,128,150,.1); color: var(--text-muted); border-color: rgba(113,128,150,.3); }
.gi-obito:hover { background: rgba(113,128,150,.2); }
.gi-transf { background: rgba(59,158,255,.1); color: var(--blue); border-color: rgba(59,158,255,.3); }
.gi-transf:hover { background: rgba(59,158,255,.2); }

/* Anteriores (giro de leito) */
.leito-anteriores {
  border-top: 1px dashed var(--border);
  margin-top: 6px;
  padding-top: 6px;
}
.leito-ant-hdr {
  display: flex;
  align-items: center;
  justify-content: space-between;
  cursor: pointer;
  font-size: .6rem;
  font-weight: 600;
  color: var(--text3);
  text-transform: uppercase;
  letter-spacing: .04em;
  padding: 2px 0;
  user-select: none;
}
.leito-ant-hdr:hover { color: var(--text2); }
.leito-ant-toggle {
  font-size: .7rem;
  transition: transform .15s;
}
.leito-ant-list {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding-top: 4px;
}
.leito-ant-item {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: .6rem;
  padding: 3px 6px;
  border-radius: var(--r-sm);
  background: var(--surface2);
}
.leito-ant-id {
  font-weight: 700;
  color: var(--text2);
  font-family: var(--font-mono);
}
.leito-ant-jh {
  color: var(--text3);
}
.leito-ant-gap {
  padding: 1px 6px;
  border-radius: 8px;
  font-size: .56rem;
  font-weight: 700;
}
.leito-ant-btns {
  margin-left: auto;
  display: flex;
  flex-direction: column;
  gap: 2px;
  align-items: center;
}
.leito-ant-del {
  background: none;
  border: none;
  color: var(--red);
  cursor: pointer;
  font-size: .6rem;
  opacity: .5;
  padding: 0 2px;
  line-height: 1;
}
.leito-ant-del:hover {
  opacity: 1;
}
.leito-ant-edit {
  background: none;
  border: none;
  color: var(--em);
  cursor: pointer;
  font-size: .55rem;
  opacity: .5;
  padding: 0 2px;
  line-height: 1;
}
.leito-ant-edit:hover {
  opacity: 1;
}
.leito-ant-editform {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
  padding: 6px 8px;
  border-radius: var(--r-sm);
  background: var(--surface2);
  border: 1px solid var(--em);
  font-size: .6rem;
}
.leito-ant-edit-fields {
  display: flex;
  gap: 8px;
  align-items: center;
}
.leito-ant-edit-fields label {
  display: flex;
  align-items: center;
  gap: 3px;
  font-size: .58rem;
  color: var(--text2);
}
.leito-ant-input {
  width: 36px;
  text-align: center;
  border: 1px solid var(--border);
  border-radius: 4px;
  padding: 2px 4px;
  font-size: .6rem;
  background: var(--surface);
  color: var(--text);
}
.leito-ant-edit-btns {
  display: flex;
  gap: 4px;
  width: 100%;
}
.leito-ant-edit-btns .leito-btn-ok {
  background: #059669 !important;
  color: #fff !important;
  font-size: .58rem !important;
  padding: 4px 12px !important;
  border: 1px solid #059669 !important;
  border-radius: var(--r-sm);
  font-weight: 700;
  cursor: pointer;
}
.leito-ant-edit-btns .leito-btn-cancel {
  background: var(--surface3) !important;
  color: var(--text2) !important;
  font-size: .58rem !important;
  padding: 4px 12px !important;
  border: 1px solid var(--border2) !important;
  border-radius: var(--r-sm);
  cursor: pointer;
}
.leito-jhadm-editable {
  cursor: pointer;
  border-bottom: 1px dashed var(--em);
  transition: color .15s;
}
.leito-jhadm-editable:hover { color: var(--em); }
.leito-edit-icon {
  font-size: .5rem;
  opacity: .35;
}
.leito-jhadm-editable:hover .leito-edit-icon { opacity: .8; }
.leito-jhadm-edit {
  display: flex;
  align-items: center;
  gap: 3px;
  flex-wrap: wrap;
}
.leito-jhadm-edit .sbtn {
  width: 22px;
  height: 22px;
  font-size: .75rem;
  min-width: 22px;
  flex-shrink: 0;
}
.leito-jhadm-val {
  min-width: 20px;
  text-align: center;
  font-weight: 700;
  font-size: .8rem;
}
.leito-jhadm-edit .leito-jhadm-ok {
  background: #059669;
  color: #fff;
  border: 1px solid #059669;
  border-radius: var(--r-sm);
  font-size: .55rem;
  padding: 3px 8px;
  cursor: pointer;
  font-weight: 700;
  white-space: nowrap;
  flex-shrink: 0;
}

/* ─── Modo Retroativo ─── */
.retro-banner {
  background: linear-gradient(90deg, rgba(245,166,35,.12), rgba(245,166,35,.04));
  border: 1px solid rgba(245,166,35,.3);
  border-radius: var(--r);
  padding: 10px 16px;
  font-size: .72rem;
  color: var(--amber);
  margin-bottom: 10px;
  text-align: center;
  letter-spacing: .02em;
}
.leito-card.leito-retro-ativo {
  background: rgba(59,158,255,.03);
  border-left: 3px solid rgba(59,158,255,.3);
}
.leito-badge-retro {
  background: rgba(59,158,255,.12);
  color: var(--blue);
  border: 1px solid rgba(59,158,255,.3);
}
.leito-retro-vazio {
  padding: 8px 0;
  text-align: center;
  color: var(--text3);
}
.leito-retro-entry {
  padding: 8px;
  border-radius: var(--r-sm);
  background: var(--surface2);
  display: flex;
  flex-direction: column;
  gap: 5px;
}
.leito-retro-entry.retro-st-alta {
  border-left: 3px solid rgba(245,166,35,.5);
}
.leito-retro-entry.retro-st-obito {
  border-left: 3px solid rgba(255,77,106,.5);
}
.leito-retro-entry.retro-st-transf {
  border-left: 3px solid rgba(167,139,250,.5);
}
.leito-retro-entry.retro-st-int {
  border-left: 3px solid rgba(0,229,160,.5);
}
.leito-retro-entry.retro-st-indef {
  border-left: 3px solid rgba(156,163,175,.5);
}
.leito-retro-pac-hdr {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 6px;
}
.leito-retro-nome {
  font-size: .68rem;
  color: var(--text);
}
.leito-retro-nome strong {
  font-size: .78rem;
  color: var(--em);
}
.leito-retro-status {
  font-size: .56rem;
  font-weight: 700;
  padding: 2px 8px;
  border-radius: 12px;
  letter-spacing: .04em;
  text-transform: uppercase;
  white-space: nowrap;
}
.leito-retro-status.retro-st-int {
  background: rgba(0,229,160,.1);
  color: var(--green);
}
.leito-retro-status.retro-st-alta {
  background: rgba(245,166,35,.12);
  color: var(--amber);
}
.leito-retro-status.retro-st-obito {
  background: rgba(255,77,106,.1);
  color: var(--red);
}
.leito-retro-status.retro-st-transf {
  background: rgba(167,139,250,.1);
  color: var(--purple);
}
.leito-retro-status.retro-st-indef {
  background: rgba(156,163,175,.1);
  color: var(--text2);
}
.leito-retro-sep {
  border: none;
  border-top: 1px dashed var(--border);
  margin: 2px 0;
}

/* Obs */
.obs-wrap {
  padding: 14px 20px;
  border-top: 1px solid var(--border);
}

.obs-wrap label {
  font-size: .68rem;
  color: var(--text3);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .06em;
  display: block;
  margin-bottom: 8px;
}

.obs-wrap textarea {
  width: 100%;
  background: var(--surface2);
  border: 1px solid var(--border2);
  color: var(--text);
  border-radius: var(--r-sm);
  padding: 10px 12px;
  font-size: .84rem;
  font-family: var(--font-body);
  resize: vertical;
  min-height: 58px;
  transition: border-color .2s;
}

.obs-wrap textarea:focus {
  outline: none;
  border-color: var(--em);
}

/* Bottom save bar */
.save-bar {
  position: sticky;
  bottom: 0;
  z-index: 100;
  background: rgba(5, 12, 24, .95);
  backdrop-filter: blur(20px);
  border-top: 1px solid var(--border2);
  padding: 14px 20px;
  display: flex;
  align-items: center;
  gap: 12px;
  margin: 20px -28px -28px;
}

.save-bar-msg {
  font-size: .78rem;
  color: var(--text2);
  flex: 1;
}

/* ═══════════════════════════════════════════
   DASHBOARD -- KPI GRID
═══════════════════════════════════════════ */
.kpi-grid {
  display: flex;
  flex-direction: column;
  gap: 0;
  margin-bottom: 28px;
  max-width: 100%;
}

/* ── Grupos colapsáveis (accordion) ── */
.kpi-group {
  border-bottom: 1px solid var(--border);
  padding-bottom: 2px;
}
.kpi-group:last-child {
  border-bottom: none;
}
.kpi-group-header {
  display: flex;
  align-items: center;
  gap: 8px;
  width: 100%;
  background: none;
  border: none;
  cursor: pointer;
  padding: 7px 4px 5px;
  text-align: left;
  color: inherit;
  user-select: none;
  border-radius: var(--r-sm);
}
.kpi-group-header:hover {
  background: rgba(255,255,255,.04);
}
.kpi-group-label {
  font-size: .68rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--text3);
  white-space: nowrap;
}
.kpi-group-line {
  flex: 1;
  height: 1px;
  background: var(--border);
  opacity: .6;
}
.kpi-group-arrow {
  font-size: .65rem;
  color: var(--text3);
  transition: transform .2s ease;
  flex-shrink: 0;
  line-height: 1;
}
.kpi-group.collapsed .kpi-group-arrow {
  transform: rotate(-90deg);
}
.kpi-group-body {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  padding: 4px 0 14px;
}
.kpi-group.collapsed .kpi-group-body {
  display: none;
}

.kcard-wrap {
  position: relative;
}

.kcard {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: 20px 16px 16px;
  position: relative;
  overflow: hidden;
  transition: border-color .3s, transform .2s, box-shadow .3s;
  cursor: default;
}

.kcard:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-card);
}

.kcard::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  border-radius: var(--r-md) var(--r-md) 0 0;
}

.kcard.cem::after {
  background: linear-gradient(90deg, var(--em), var(--em2));
}

.kcard.cbl::after {
  background: linear-gradient(90deg, var(--blue), #60a5fa);
}

.kcard.camb::after {
  background: linear-gradient(90deg, var(--amber), #fbbf24);
}

.kcard.cred::after {
  background: linear-gradient(90deg, var(--red), #fb7185);
}

.kcard.cpur::after {
  background: linear-gradient(90deg, var(--purple), #c4b5fd);
}

.kcard.cgr::after {
  background: linear-gradient(90deg, var(--em), #34d399);
}

.kcard.cem {
  box-shadow: inset 0 0 40px rgba(0, 229, 160, .04);
}

.kcard.cred {
  box-shadow: inset 0 0 40px rgba(255, 77, 106, .04);
}

.klabel {
  font-size: .63rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--text3);
  margin-bottom: 10px;
}

.kval {
  font-family: var(--font-mono);
  font-size: 2rem;
  font-weight: 500;
  line-height: 1;
  margin-bottom: 6px;
  transition: transform .3s;
}

.kcard.cem .kval {
  color: var(--em);
}

.kcard.cbl .kval {
  color: var(--blue);
}

.kcard.camb .kval {
  color: var(--amber);
}

.kcard.cred .kval {
  color: var(--red);
}

.kcard.cpur .kval {
  color: var(--purple);
}

.kcard.cgr .kval {
  color: var(--em);
}

.ksub {
  font-size: .67rem;
  color: var(--text3);
  line-height: 1.4;
}

/* Formula button */
.fbtn {
  position: absolute;
  top: 8px;
  right: 8px;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: rgba(255, 255, 255, .07);
  border: none;
  color: var(--text3);
  cursor: pointer;
  font-size: .62rem;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all .2s;
  z-index: 2;
}

.fbtn:hover {
  background: var(--em-dim);
  color: var(--em);
}

.fpopup {
  position: absolute;
  width: 290px;
  max-width: calc(100vw - 32px);
  background: var(--surface);
  border: 1px solid var(--border2);
  border-radius: var(--r-md);
  padding: 16px 18px 14px;
  z-index: 50;
  box-shadow: 0 8px 32px rgba(0,0,0,.12), 0 2px 6px rgba(0,0,0,.06);
  display: none;
  pointer-events: none;
}

.fpopup.open {
  display: block;
  pointer-events: auto;
  animation: popIn .2s ease;
}

.fp-close {
  position: absolute;
  top: 6px; right: 8px;
  background: none; border: none;
  color: var(--text3); cursor: pointer;
  font-size: 1.1rem; line-height: 1;
  padding: 2px 4px;
}
.fp-close:hover { color: var(--red); }

@keyframes popIn {
  from {
    opacity: 0;
    transform: scale(.95) translateY(-4px);
  }

  to {
    opacity: 1;
    transform: scale(1) translateY(0);
  }
}

.fpopup h4 {
  font-size: .68rem;
  font-weight: 700;
  color: var(--em);
  text-transform: uppercase;
  letter-spacing: .07em;
  margin-bottom: 7px;
}

.fpopup p {
  font-size: .74rem;
  color: var(--text2);
  line-height: 1.55;
  margin-bottom: 5px;
}

.fpopup code {
  display: block;
  background: var(--em-dim);
  border-radius: var(--r-sm);
  padding: 6px 9px;
  font-family: var(--font-mono);
  font-size: .69rem;
  color: var(--em);
  margin-top: 5px;
}

.fpopup .ref {
  font-size: .63rem;
  color: var(--text3);
  margin-top: 7px;
  font-style: italic;
}

/* ═══════════════════════════════════════════
   DASHBOARD -- CHARTS
═══════════════════════════════════════════ */
.charts-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  margin-bottom: 14px;
}

.charts-grid.wide {
  grid-template-columns: 1fr;
}

@media (max-width: 700px) {
  .charts-grid {
    grid-template-columns: 1fr;
  }
}

.ccard {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 20px;
  position: relative;
  transition: border-color .3s;
  display: flex;
  flex-direction: column;
}

.chart-wrap {
  position: relative;
  height: 240px;
  width: 100%;
}

.ccard.wide .chart-wrap {
  height: 280px;
}

.comparativo-card {
  max-width: 100%;
  box-sizing: border-box;
}

.comparativo-card .chart-wrap {
  height: 320px;
}

.ccard:hover {
  border-color: var(--border2);
}

.ccard-hdr {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  margin-bottom: 16px;
  gap: 8px;
}

.ccard-title {
  font-size: .72rem;
  font-weight: 700;
  color: var(--text2);
  text-transform: uppercase;
  letter-spacing: .08em;
}

.ccard-sub {
  font-size: .64rem;
  color: var(--text3);
  margin-top: 3px;
}

.cfbtn {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: rgba(255, 255, 255, .06);
  border: none;
  color: var(--text3);
  cursor: pointer;
  font-size: .65rem;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: all .2s;
  z-index: 2;
}

.cfbtn:hover {
  background: var(--em-dim);
  color: var(--em);
}

/* ═══════════════════════════════════════════
   DASHBOARD -- TABLE
═══════════════════════════════════════════ */
.table-wrap {
  overflow-x: auto;
  border-radius: var(--r-md);
  border: 1px solid var(--border);
}

table.dtable {
  width: 100%;
  border-collapse: collapse;
  font-size: .78rem;
}

table.dtable th {
  background: var(--surface2);
  padding: 9px 12px;
  border: 1px solid var(--border);
  font-size: .63rem;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--text3);
  white-space: nowrap;
  position: sticky;
  top: 0;
  z-index: 2;
}

table.dtable td {
  border: 1px solid var(--border);
  padding: 0;
  text-align: center;
  vertical-align: middle;
}

table.dtable th.dlabel {
  position: sticky;
  left: 0;
  z-index: 3;
  background: var(--surface2);
}

table.dtable td.dlabel {
  padding: 7px 12px;
  text-align: left;
  font-weight: 500;
  color: var(--text2);
  position: sticky;
  left: 0;
  z-index: 1;
  background: var(--surface);
  white-space: nowrap;
  font-size: .72rem;
  min-width: 185px;
  border-right: 2px solid var(--border2);
}

table.dtable .col-hoje {
  background: var(--em-dim);
}
table.dtable th.col-hoje {
  color: var(--em);
  font-weight: 700;
}

table.dtable td.dtotal {
  background: var(--em-dim);
  color: var(--em);
  font-family: var(--font-mono);
  font-weight: 700;
  padding: 6px 10px;
}

.cedit {
  width: 100%;
  border: none;
  background: transparent;
  color: var(--text);
  text-align: center;
  font-size: .78rem;
  font-family: var(--font-mono);
  padding: 7px 4px;
  cursor: pointer;
  min-width: 44px;
}

.cedit:focus {
  outline: none;
  background: var(--em-dim);
  color: var(--em);
}

.cedit:hover:not(:focus) {
  background: rgba(255, 255, 255, .04);
}

/* Campo derivado automaticamente do Mapa de Leitos — somente-leitura na planilha */
.cedit-mapa {
  opacity: .4;
  cursor: not-allowed;
  color: var(--em);
  background: transparent;
}

tr.trow-total td {
  background: var(--em-dim);
  color: var(--em);
  font-weight: 700;
  font-family: var(--font-mono);
}

tr.trow-total td.dlabel {
  background: rgba(0, 229, 160, .12);
  color: var(--em);
}

/* ═══════════════════════════════════════════
   BULK BAR
═══════════════════════════════════════════ */
.bulk-bar {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: 13px 18px;
  margin-bottom: 14px;
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.bulk-label {
  font-size: .78rem;
  font-weight: 700;
  color: var(--amber);
}

.bulk-sel {
  background: var(--surface2);
  border: 1px solid var(--border2);
  color: var(--text);
  padding: 7px 10px;
  border-radius: var(--r-sm);
  font-size: .8rem;
  max-width: 240px;
}

.bulk-inp {
  background: var(--surface2);
  border: 1px solid var(--border2);
  color: var(--text);
  padding: 7px 10px;
  border-radius: var(--r-sm);
  font-size: .84rem;
  width: 76px;
  text-align: center;
  font-family: var(--font-mono);
}

.bulk-inp:focus {
  outline: none;
  border-color: var(--em);
}

/* ═══════════════════════════════════════════
   CONFIG
═══════════════════════════════════════════ */
.cfg-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 24px;
  margin-bottom: 16px;
}

.cfg-card h3 {
  font-size: 1rem;
  font-weight: 700;
  margin-bottom: 6px;
}

.cfg-card .desc {
  color: var(--text2);
  font-size: .82rem;
  margin-bottom: 18px;
  line-height: 1.6;
}

.uti-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 16px;
}

.uti-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 11px 15px;
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  transition: border-color .2s;
}

.uti-item:hover {
  border-color: var(--border2);
}

.uti-num {
  font-size: .7rem;
  color: var(--text3);
  font-family: var(--font-mono);
  min-width: 22px;
}

.uti-name-text {
  flex: 1;
  font-size: .88rem;
  font-weight: 500;
}

.del-uti {
  background: var(--red-dim);
  border: none;
  color: var(--red);
  padding: 4px 11px;
  border-radius: 6px;
  cursor: pointer;
  font-size: .72rem;
  font-weight: 700;
  transition: background .2s;
}

.del-uti:hover {
  background: rgba(255, 77, 106, .25);
}

.edit-uti {
  background: rgba(59, 158, 255, .15);
  border: none;
  color: var(--blue);
  padding: 4px 11px;
  border-radius: 6px;
  cursor: pointer;
  font-size: .72rem;
  font-weight: 700;
  transition: background .2s;
}

.edit-uti:hover {
  background: rgba(59, 158, 255, .3);
}

.add-row {
  display: flex;
  gap: 10px;
}

.add-inp {
  flex: 1;
  background: var(--surface2);
  border: 1px solid var(--border2);
  color: var(--text);
  padding: 11px 15px;
  border-radius: var(--r-sm);
  font-family: var(--font-body);
  font-size: .88rem;
  transition: border-color .2s;
}

.add-inp:focus {
  outline: none;
  border-color: var(--em);
}

.empty-list {
  color: var(--text3);
  font-size: .84rem;
  padding: 18px;
  text-align: center;
  border: 1px dashed var(--border2);
  border-radius: var(--r-sm);
}

/* ═══════════════════════════════════════════
   HISTÓRICO
═══════════════════════════════════════════ */
.hist-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 12px;
}

.hcard {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: 16px;
  transition: border-color .25s, transform .2s;
}

.hcard:hover {
  border-color: var(--border2);
  transform: translateY(-1px);
}

.hc-top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 12px;
}

.hc-date {
  font-weight: 700;
  font-size: .95rem;
  font-family: var(--font-mono);
}

.hc-uti {
  font-size: .7rem;
  color: var(--em);
  background: var(--em-dim);
  padding: 2px 9px;
  border-radius: 20px;
  font-weight: 600;
}

.hc-stats {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 12px;
}

.hstat .sv {
  font-family: var(--font-mono);
  font-weight: 500;
  font-size: 1.05rem;
  color: var(--em);
}

.hstat .sl {
  font-size: .62rem;
  color: var(--text3);
  text-transform: uppercase;
  letter-spacing: .04em;
}

.hc-actions {
  display: flex;
  gap: 7px;
}

.hbtn {
  flex: 1;
  padding: 7px;
  border-radius: var(--r-sm);
  border: 1px solid var(--border2);
  background: var(--surface2);
  color: var(--text2);
  cursor: pointer;
  font-size: .74rem;
  font-family: var(--font-body);
  font-weight: 600;
  transition: all .15s;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
}

.hbtn:hover {
  border-color: var(--em);
  color: var(--em);
}

.hbtn.del:hover {
  border-color: var(--red);
  color: var(--red);
}

.empty-state {
  text-align: center;
  padding: 60px 20px;
  color: var(--text3);
}

.empty-state .ei {
  font-size: 2.8rem;
  margin-bottom: 12px;
}

/* ═══════════════════════════════════════════
   MODAL
═══════════════════════════════════════════ */
.modal-ov {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, .8);
  z-index: 800;
  display: none;
  align-items: center;
  justify-content: center;
  backdrop-filter: blur(8px);
}

.modal-ov.open {
  display: flex;
}

.modal {
  background: var(--surface);
  border: 1px solid var(--border2);
  border-radius: var(--r-lg);
  padding: 28px;
  width: min(420px, 92vw);
  animation: lockIn .3s cubic-bezier(.16, 1, .3, 1);
}

.modal h3 {
  font-family: var(--font-head);
  font-size: 1.15rem;
  font-style: italic;
  margin-bottom: 8px;
}

.modal p {
  color: var(--text2);
  font-size: .86rem;
  margin-bottom: 20px;
  line-height: 1.5;
}

.modal-btns {
  display: flex;
  gap: 9px;
  justify-content: flex-end;
}

/* ═══════════════════════════════════════════
   MODAL AUDITORIA GERAL
═══════════════════════════════════════════ */
.audit-modal {
  width: min(780px, 96vw);
  max-height: 90vh;
  display: flex;
  flex-direction: column;
  padding: 0;
}
.audit-modal-hdr {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 20px 24px 12px;
  border-bottom: 1px solid var(--border);
}
.audit-modal-hdr h3 {
  margin: 0;
  font-size: 1.1rem;
}
.audit-filters {
  display: flex;
  gap: 8px;
  padding: 12px 24px;
  flex-wrap: wrap;
  border-bottom: 1px solid var(--border);
}
.audit-filters .af-btn {
  padding: 5px 12px;
  border-radius: 16px;
  border: 1px solid var(--border);
  background: transparent;
  color: var(--text2);
  font-size: .72rem;
  cursor: pointer;
  font-family: var(--font-body);
  transition: all .2s;
}
.audit-filters .af-btn.active {
  background: var(--primary);
  color: #fff;
  border-color: var(--primary);
}
.audit-filters .af-btn:hover:not(.active) {
  border-color: var(--primary);
  color: var(--primary);
}
.audit-body {
  flex: 1;
  overflow-y: auto;
  padding: 16px 24px;
  font-size: .8rem;
}
.audit-footer {
  padding: 12px 24px;
  border-top: 1px solid var(--border);
  font-size: .72rem;
  color: var(--text3);
  text-align: center;
}
.audit-card {
  background: rgba(255,255,255,.03);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 12px 14px;
  margin-bottom: 10px;
}
.audit-card-hdr {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 8px;
}
.audit-card-day {
  font-weight: 600;
  color: var(--accent);
  font-size: .85rem;
}
.audit-card-fisio {
  color: var(--text3);
  font-size: .72rem;
}
.audit-item {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  padding: 6px 0;
  border-bottom: 1px solid rgba(255,255,255,.04);
}
.audit-item:last-child {
  border-bottom: none;
}
.audit-sev {
  flex-shrink: 0;
  width: 22px;
  height: 22px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  font-size: .65rem;
}
.audit-sev-crit { background: rgba(220,38,38,.2); color: var(--red); }
.audit-sev-warn { background: rgba(245,166,35,.2); color: #f5a623; }
.audit-sev-info { background: rgba(59,158,255,.2); color: #3b9eff; }
.audit-detail {
  flex: 1;
}
.audit-detail-field {
  font-weight: 600;
  color: var(--text1);
}
.audit-detail-msg {
  color: var(--text2);
  margin-top: 2px;
}
.audit-detail-tip {
  color: var(--text3);
  font-size: .68rem;
  margin-top: 2px;
  font-style: italic;
}
.audit-summary {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 14px;
}
.audit-stat {
  background: var(--surface2, rgba(255,255,255,.05));
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 10px 16px;
  text-align: center;
  flex: 1;
  min-width: 100px;
}
.audit-stat-val {
  font-size: 1.3rem;
  font-weight: 700;
  font-family: var(--font-head);
}
.audit-stat-lbl {
  font-size: .68rem;
  color: var(--text3);
  margin-top: 2px;
}

/* ═══════════════════════════════════════════
   TOAST
═══════════════════════════════════════════ */
.toast {
  position: fixed;
  bottom: 28px;
  right: 28px;
  background: var(--em);
  color: #021a0e;
  padding: 12px 24px;
  border-radius: var(--r-md);
  font-family: var(--font-body);
  font-weight: 700;
  font-size: .84rem;
  opacity: 0;
  transform: translateY(12px) scale(.95);
  transition: all .3s cubic-bezier(.16, 1, .3, 1);
  z-index: 9999;
  pointer-events: none;
  box-shadow: 0 8px 32px rgba(0, 229, 160, .3);
}

.toast.show {
  opacity: 1;
  transform: translateY(0) scale(1);
}

.toast.err {
  background: var(--red);
  color: #fff;
  box-shadow: 0 8px 32px rgba(255, 77, 106, .3);
}

.toast.info {
  background: var(--blue);
  color: #fff;
  box-shadow: 0 8px 32px rgba(59, 158, 255, .25);
}

.toast.warn {
  background: #e67e22;
  color: #fff;
  box-shadow: 0 8px 32px rgba(230, 126, 34, .35);
}

/* ═══════════════════════════════════════════
   NUMBER ANIMATION
═══════════════════════════════════════════ */
@keyframes countUp {
  from {
    opacity: 0;
    transform: translateY(8px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.kval.animating {
  animation: countUp .4s cubic-bezier(.16, 1, .3, 1);
}

/* ═══════════════════════════════════════════
   SCROLLBAR
═══════════════════════════════════════════ */
::-webkit-scrollbar {
  width: 6px;
  height: 6px;
}

::-webkit-scrollbar-track {
  background: transparent;
}

::-webkit-scrollbar-thumb {
  background: var(--border2);
  border-radius: 3px;
}

::-webkit-scrollbar-thumb:hover {
  background: var(--text3);
}

/* ═══════════════════════════════════════════
   FIELD TOOLTIPS
═══════════════════════════════════════════ */
.fcell-row {
  display: flex;
  align-items: center;
  gap: 5px;
  margin-bottom: 5px;
}

.fcell-row label {
  flex: 1;
  margin-bottom: 0;
  font-size: .65rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--text3);
}

.ftip-btn {
  flex-shrink: 0;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: rgba(167, 139, 250, .15);
  border: 1px solid rgba(167, 139, 250, .3);
  color: var(--purple);
  font-size: .58rem;
  font-weight: 800;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: all .15s;
  font-family: var(--font-body);
  line-height: 1;
  padding: 0;
}

.ftip-btn:hover {
  background: var(--purple);
  color: #fff;
  transform: scale(1.15);
  box-shadow: 0 0 8px rgba(167, 139, 250, .4);
}

.ftip-popup {
  position: fixed;
  z-index: 9999;
  width: 270px;
  background: var(--surface);
  border: 1px solid var(--border2);
  border-radius: 12px;
  padding: 14px 16px 12px;
  box-shadow: 0 8px 32px rgba(0,0,0,.12), 0 2px 6px rgba(0,0,0,.06);
  animation: ftipIn .18s cubic-bezier(.16, 1, .3, 1);
  pointer-events: none;
}

@keyframes ftipIn {
  from {
    opacity: 0;
    transform: translateY(6px) scale(.97);
  }

  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

.ftip-popup .fp-title {
  font-size: .78rem;
  font-weight: 700;
  color: var(--purple);
  margin-bottom: 5px;
}

.ftip-popup .fp-desc {
  font-size: .74rem;
  color: var(--text2);
  line-height: 1.45;
  margin-bottom: 7px;
}

.ftip-popup .fp-formula {
  font-family: var(--font-mono);
  font-size: .7rem;
  color: var(--em2);
  background: var(--em-dim);
  border-radius: 6px;
  padding: 5px 8px;
}

/* ═══ Sbtn maior e SUPER tactil para Mobile ═══ */
.sbtn {
  width: 44px !important;
  height: 44px !important;
  font-size: 1.5rem !important;
  border-radius: 10px !important;
  background: rgba(255, 255, 255, 0.06) !important;
  touch-action: manipulation;
  transition: all 0.2s cubic-bezier(0.18, 0.89, 0.32, 1.28) !important;
}

.sbtn:hover,
.sbtn:active {
  background: var(--em) !important;
  color: #000 !important;
  transform: scale(1.05);
  box-shadow: 0 0 20px rgba(0, 229, 160, .4);
}

.sval {
  font-size: 1.3rem !important;
  min-width: 54px !important;
  padding: 6px !important;
  font-weight: 700 !important;
}

/* ═══ VM Calc badge mais destacado ═══ */
.vm-calc {
  margin: 12px 16px 6px !important;
  padding: 12px 16px !important;
  background: linear-gradient(135deg, rgba(59, 158, 255, .14), rgba(167, 139, 250, .1)) !important;
  border: 1px solid rgba(59, 158, 255, .35) !important;
  border-radius: 10px;
  display: flex;
  align-items: center;
  gap: 14px;
  font-size: .88rem;
  font-weight: 600;
}

#vm-calc-val {
  font-size: 1.6rem !important;
  font-family: var(--font-mono);
  font-weight: 700;
  color: var(--blue) !important;
  text-shadow: 0 0 14px rgba(59, 158, 255, .5);
  transition: all .3s;
}

/* ═══ KPI cards glow ═══ */
.kcard.cem:hover {
  box-shadow: 0 6px 24px rgba(0, 229, 160, .15), inset 0 0 40px rgba(0, 229, 160, .06);
}

.kcard.cbl:hover {
  box-shadow: 0 6px 24px rgba(59, 158, 255, .15);
}

.kcard.camb:hover {
  box-shadow: 0 6px 24px rgba(245, 166, 35, .15);
}

.kcard.cred:hover {
  box-shadow: 0 6px 24px rgba(255, 77, 106, .15);
}

.kcard.cpur:hover {
  box-shadow: 0 6px 24px rgba(167, 139, 250, .15);
}

/* ═══ Gcard top border accent ═══ */
.gcard.g-census {
  border-top: 2px solid var(--em);
}

.gcard.g-vm {
  border-top: 2px solid var(--blue);
}

.gcard.g-mob {
  border-top: 2px solid var(--purple);
}

.gcard.g-events {
  border-top: 2px solid var(--red);
}

.gcard.g-quality {
  border-top: 2px solid var(--amber);
}

/* ═══ Btn-primary mais vibrante ═══ */
.btn-primary {
  box-shadow: 0 0 20px rgba(0, 229, 160, .35) !important;
}

.btn-primary:hover {
  box-shadow: 0 0 32px rgba(0, 229, 160, .5) !important;
}

/* ═══════════════════════════════════════════
   RESPONSIVIDADE GERAL (MOBILE)
═══════════════════════════════════════════ */
/* Hamburger toggle — escondido no desktop */
.hamburger-btn {
  display: none;
  background: none;
  border: 1px solid rgba(255,255,255,.15);
  border-radius: var(--r-sm);
  color: var(--text2);
  font-size: 1.4rem;
  padding: 6px 10px;
  cursor: pointer;
  line-height: 1;
  transition: all .15s;
}
.hamburger-btn:hover { background: rgba(255,255,255,.08); color:#fff; }

/* Drawer overlay */
.nav-drawer-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.45);
  backdrop-filter: blur(4px);
  z-index: 300;
}
.nav-drawer-overlay.open { display: block; }

/* Nav drawer (mobile) */
.nav.drawer {
  position: fixed;
  top: 0; right: 0; bottom: 0;
  width: 260px;
  max-width: 80vw;
  background: rgba(5,12,24,.97);
  backdrop-filter: blur(20px);
  flex-direction: column;
  align-items: stretch;
  padding: 24px 16px;
  gap: 4px;
  z-index: 310;
  transform: translateX(100%);
  transition: transform .25s ease;
  overflow-y: auto;
}
.nav.drawer.open { transform: translateX(0); }
.nav.drawer .nav-btn {
  text-align: left;
  padding: 12px 16px;
  font-size: .85rem;
  border-radius: var(--r-sm);
}
.nav-drawer-close {
  align-self: flex-end;
  background: none; border: none;
  color: var(--text3); font-size: 1.5rem;
  cursor: pointer; padding: 4px 8px;
  margin-bottom: 12px;
}
.nav-drawer-close:hover { color:#fff; }

@media (max-width: 850px) {
  .hamburger-btn { display: flex; align-items: center; justify-content: center; }

  .nav:not(.drawer) { display: none; }

  .header {
    height: auto;
    padding: 12px 16px;
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
    gap: 8px;
  }

  .logo-mark {
    flex: 1;
  }

  .header-right {
    gap: 6px;
    flex-wrap: nowrap;
  }

  .page-hdr {
    flex-direction: column;
    align-items: flex-start;
    gap: 10px;
  }

  .page-hdr h2 {
    font-size: 1.4rem;
    margin-bottom: 6px;
  }

  .page-hdr select,
  .page-hdr button {
    width: 100%;
  }

  .uti-wrap {
    width: 100%;
  }

  /* Ajuste nas colunas dos botões de via aérea e calculadoras no celular */
  .va-row {
    flex-direction: column;
    align-items: flex-start;
  }

  .bulk-bar {
    flex-direction: column;
    align-items: stretch;
  }

  .bulk-sel,
  .bulk-inp {
    max-width: 100%;
    width: 100%;
  }
}

/* ═══════════════════════════════════════════
   PRINT / PDF (RELATÓRIO PDF EXECUTIVO)
═══════════════════════════════════════════ */
@media print {
  body {
    background: #fff !important;
    color: #000 !important;
    margin: 0;
    padding: 0;
  }

  .header,
  .nav,
  .save-bar,
  .bulk-bar,
  .fpopup,
  .toast,
  .btn-ghost,
  .btn-primary,
  .cfbtn,
  .uti-arrow {
    display: none !important;
  }

  .view:not(#view-dashboard) {
    display: none !important;
  }

  #view-dashboard {
    display: block !important;
    animation: none;
    padding: 0;
    border: none;
  }

  .page-hdr {
    border-bottom: 2px solid #000 !important;
    padding-bottom: 10px !important;
    margin-bottom: 20px !important;
    align-items: center;
    text-align: center;
    justify-content: center;
  }

  .page-hdr h2 {
    font-size: 20pt !important;
    color: #000 !important;
  }

  .page-hdr select {
    appearance: none;
    border: none !important;
    font-size: 14pt !important;
    text-align: center;
    color: #555 !important;
    background: transparent !important;
    margin-left: 10px;
    font-weight: bold;
  }

  .kpi-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 10px !important;
    margin-bottom: 20px !important;
  }

  .kcard {
    page-break-inside: avoid;
    border: 1px solid #ddd !important;
    box-shadow: none !important;
    background: #fff !important;
    margin: 0 !important;
    padding: 12px !important;
  }

  .kval {
    color: #000 !important;
    font-size: 20pt !important;
  }

  .ktitle {
    color: #555 !important;
    font-size: 9pt !important;
  }

  .charts-grid {
    display: block !important;
    margin-bottom: 20px;
  }

  .ccard {
    page-break-inside: avoid;
    background: #fff !important;
    box-shadow: none !important;
    border: 1px solid #ddd !important;
    margin-bottom: 15px;
  }

  .ccard-title {
    color: #000 !important;
  }

  .ccard-sub {
    color: #666 !important;
  }

  .gcard {
    border: 1px solid #aaa !important;
    margin-top: 20px;
    page-break-inside: avoid;
  }

  .gtitle {
    background: #eee !important;
    color: #000 !important;
    margin: 0 !important;
    border-bottom: 1px solid #aaa !important;
  }

  .dtable th {
    background: #ddd !important;
    color: #000 !important;
    border-color: #000 !important;
  }

  .dtable td {
    border-color: #000 !important;
    color: #000 !important;
  }

  .pdf-footer {
    display: block !important;
    margin-top: 40px;
    font-size: 10pt;
    color: #000;
    page-break-before: always;
  }

  .pdf-ref {
    margin-bottom: 15px;
    padding-bottom: 15px;
    border-bottom: 1px dashed #ccc;
  }

  .pdf-ref h4 {
    font-size: 11pt;
    margin: 0 0 4px;
    color: #000;
    font-weight: bold;
  }

  .pdf-ref p {
    margin: 0 0 4px;
    color: #333;
  }

  .pdf-ref code {
    display: inline-block;
    background: #eee;
    padding: 3px 6px;
    border: 1px solid #ccc;
    font-family: monospace;
  }

  canvas {
    max-width: 100% !important;
    max-height: 250px !important;
  }

  /* Previne estouro de graficos na folha A4 */
}

/* ═══ PATCH: TOOLTIP POPUP ═══ */
.tip-btn {
  width: 17px;
  height: 17px;
  border-radius: 50%;
  background: rgba(167, 139, 250, .18);
  border: 1px solid rgba(167, 139, 250, .35);
  color: var(--purple);
  font-size: .62rem;
  font-weight: 700;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: all .15s;
  line-height: 1;
  padding: 0;
  font-family: var(--font-body);
}

.tip-btn:hover {
  background: var(--purple);
  color: #fff;
  transform: scale(1.15);
}

.tip-popup {
  position: fixed;
  z-index: 9999;
  width: 280px;
  background: #0d1628;
  border: 1px solid rgba(167, 139, 250, .4);
  border-radius: 12px;
  padding: 14px 16px;
  box-shadow: 0 12px 40px rgba(0, 0, 0, .7), 0 0 0 1px rgba(255, 255, 255, .04);
  animation: tipIn .2s cubic-bezier(.16, 1, .3, 1);
}

@keyframes tipIn {
  from {
    opacity: 0;
    transform: translateY(6px)
  }

  to {
    opacity: 1;
    transform: translateY(0)
  }
}

.tip-title {
  font-size: .8rem;
  font-weight: 700;
  color: var(--purple);
  margin-bottom: 5px;
}

.tip-desc {
  font-size: .77rem;
  color: var(--text2);
  line-height: 1.45;
  margin-bottom: 6px;
}

.tip-meta {
  font-size: .72rem;
  font-family: var(--font-mono);
  color: var(--em);
  background: rgba(0, 229, 160, .07);
  border-radius: 6px;
  padding: 5px 8px;
}

.tip-close {
  position: absolute;
  top: 8px;
  right: 10px;
  background: transparent;
  border: none;
  color: var(--text3);
  cursor: pointer;
  font-size: .9rem;
}

.tip-close:hover {
  color: var(--red);
}

/* ═══ PATCH: FCELL - header para label + tip btn ═══ */
.fcell-hdr {
  display: flex;
  align-items: center;
  gap: 5px;
  margin-bottom: 4px;
}

.fcell-hdr label {
  margin-bottom: 0;
  flex: 1;
}

/* ═══ PATCH: SBTN melhorado ═══ */
.sbtn-plus:hover {
  background: var(--em-dim);
  border-color: var(--em);
  color: var(--em);
}

/* ═══ PATCH: VM Calc display destacado ═══ */
.vm-calc {
  display: flex;
  align-items: center;
  gap: 12px;
  margin: 10px 15px 4px;
  padding: 10px 14px;
  background: linear-gradient(135deg, rgba(59, 158, 255, .12), rgba(167, 139, 250, .1));
  border: 1px solid rgba(59, 158, 255, .3);
  border-radius: 10px;
  font-size: .85rem;
  font-weight: 600;
}

#vm-calc-val {
  font-size: 1.4rem;
  font-family: var(--font-mono);
  font-weight: 700;
  color: var(--blue);
  text-shadow: 0 0 12px rgba(59, 158, 255, .5);
}

/* ═══ PATCH: gcard gradients mais vibrantes ═══ */
.gcard.g-census {
  border-top: 2px solid var(--em);
}

.gcard.g-vm {
  border-top: 2px solid var(--blue);
}

.gcard.g-mob {
  border-top: 2px solid var(--purple);
}

.gcard.g-events {
  border-top: 2px solid var(--red);
}

.gcard.g-quality {
  border-top: 2px solid var(--amber);
}

/* Animacao sequencial nos fcells */
.fcell {
  animation: fcellIn .3s ease-out backwards;
}

@keyframes fcellIn {
  from {
    opacity: 0;
    transform: translateY(8px)
  }

  to {
    opacity: 1;
    transform: translateY(0)
  }
}

/* Glow nos KPI cards */
.kcard {
  transition: transform .2s, box-shadow .2s;
  cursor: default;
}

.kcard:hover {
  transform: translateY(-3px);
}

/* ═══ PATCH: Nav bar melhor ═══ */
.nav-btn {
  letter-spacing: .01em;
}

.nav-btn.active {
  box-shadow: 0 0 16px rgba(0, 229, 160, .2);
}

/* ═══ PATCH: save-bar mais vibrante ═══ */
.btn-primary {
  background: linear-gradient(120deg, #00e5a0, #00c487);
  box-shadow: 0 0 20px rgba(0, 229, 160, .35);
  letter-spacing: .02em;
}

.btn-primary:hover {
  box-shadow: 0 0 30px rgba(0, 229, 160, .5);
}

/* ═══ PATCH: Charts grid ═══ */
.charts-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  margin-bottom: 14px;
}

.charts-grid.wide {
  grid-template-columns: 1fr;
}

@media(max-width:900px) {
  .charts-grid {
    grid-template-columns: 1fr;
  }
}

.ccard {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 18px 16px;
}

.ccard-hdr {
  display: flex;
  align-items: flex-start;
  gap: 6px;
  margin-bottom: 12px;
}

.ccard-title {
  font-size: .82rem;
  font-weight: 700;
  color: var(--text);
}

.ccard-sub {
  font-size: .7rem;
  color: var(--text3);
  margin-top: 2px;
}

.cfbtn {
  margin-left: auto;
  flex-shrink: 0;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: var(--purple-dim);
  border: 1px solid rgba(167, 139, 250, .3);
  color: var(--purple);
  font-size: .65rem;
  font-weight: 700;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all .15s;
}

.cfbtn:hover {
  background: var(--purple);
  color: #fff;
}

/* ── NOVA TELA DE LOGIN (design claro, centralizado) ── */
#lock-screen.lock-overlay {
  background: linear-gradient(150deg, #c6e9f7 0%, #b8ede6 55%, #c4f0ea 100%);
  backdrop-filter: none;
  align-items: center;
  justify-content: center;
  padding: 28px 16px;
  overflow-y: auto;
}

/* Wrapper central */
.lock-center-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
  max-width: 430px;
}

/* Seção de marca (logo + título + subtítulo) */
.lock-brand {
  text-align: center;
  margin-bottom: 28px;
}

/* Caixa branca ao redor da logo */
.lock-logo-box {
  width: 100px;
  height: 100px;
  background: #fff;
  border-radius: 24px;
  box-shadow: 0 8px 28px rgba(0, 0, 0, 0.10);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 18px auto;
  overflow: hidden;
}

.lock-logo-new {
  width: 82px;
  height: 82px;
  object-fit: contain;
}

.lock-brand-title {
  font-size: 1.45rem;
  font-weight: 700;
  color: #1a202c;
  margin-bottom: 8px;
  font-family: var(--font-body);
}

.lock-brand-green {
  color: #00c587;
}

.lock-brand-sub {
  font-size: 0.87rem;
  color: #4a5568;
  line-height: 1.55;
  max-width: 320px;
  margin: 0 auto;
}

/* Features list — hidden on mobile, shown desktop-only via media query */
.lock-features { display: none; list-style: none; padding: 0; margin: 0; }
.lock-feat-icon { display: none; }

/* Card de login */
#lock-screen .lock-card {
  background: #ffffff;
  border: none;
  border-radius: 22px;
  padding: 34px 36px 28px;
  box-shadow: 0 6px 36px rgba(0, 0, 0, 0.10);
  width: 100%;
  max-width: 430px;
  animation: lockIn .5s cubic-bezier(.16, 1, .3, 1);
  text-align: left;
}

/* Indicador de progresso (pontos + linha) */
.lock-progress-dots {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 26px;
  gap: 0;
}

.lpd-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #cbd5e1;
  flex-shrink: 0;
}

.lpd-dot.active {
  background: #0097b2;
}

.lpd-line {
  width: 52px;
  height: 2.5px;
  background: linear-gradient(90deg, #0097b2, #00c4a7);
  margin: 0 3px;
  border-radius: 2px;
}

/* Título e subtítulo do card */
#lock-screen .lock-card-title {
  font-family: Georgia, 'Times New Roman', serif;
  font-size: 1.85rem;
  font-style: italic;
  font-weight: 700;
  color: #1a202c;
  text-align: center;
  margin-bottom: 6px;
}

#lock-screen .lock-card-sub {
  font-size: .86rem;
  color: #64748b;
  text-align: center;
  margin-bottom: 26px;
  line-height: 1.5;
}

/* Labels */
#lock-screen .lock-label {
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .8px;
  text-transform: uppercase;
  color: #718096;
  display: block;
  margin-bottom: 7px;
}

/* Inputs — sobrescreve o estilo dark do tema base */
#lock-screen .lock-input {
  background: #f7fafc;
  border: 1.5px solid #e2e8f0;
  color: #1a202c;
  border-radius: 11px;
  font-size: .95rem;
  padding: 13px 16px;
  letter-spacing: normal;
  font-family: var(--font-body);
  text-align: left;
  margin-bottom: 0;
  transition: border-color .2s, box-shadow .2s;
}

#lock-screen .lock-input:focus {
  outline: none;
  border-color: #0097b2;
  box-shadow: 0 0 0 3px rgba(0, 151, 178, 0.13);
}

#lock-screen .lock-input::placeholder {
  color: #a0aec0;
}

/* Botão Entrar */
#lock-screen .lock-btn {
  background: linear-gradient(135deg, #0097b2 0%, #00c4a7 100%);
  color: #fff;
  border: none;
  border-radius: 12px;
  font-size: 1rem;
  font-weight: 700;
  padding: 15px;
  cursor: pointer;
  width: 100%;
  margin-top: 10px;
  margin-bottom: 0;
  transition: opacity .2s, transform .1s;
  letter-spacing: .3px;
}

#lock-screen .lock-btn:hover {
  opacity: .92;
  transform: translateY(-1px);
}

#lock-screen .lock-btn:active {
  transform: translateY(0);
  opacity: 1;
}

/* Link "Esqueci minha senha" */
#lock-screen .lock-forgot-btn {
  background: none;
  border: none;
  color: #0097b2;
  font-size: .87rem;
  font-weight: 500;
  cursor: pointer;
  width: 100%;
  padding: 11px 0 0;
  text-align: center;
  text-decoration: none;
  transition: color .2s;
  display: block;
}

#lock-screen .lock-forgot-btn:hover {
  color: #006d82;
  text-decoration: underline;
}

/* Divisor */
.lock-divider {
  height: 1px;
  background: #e2e8f0;
  margin: 22px 0 16px;
}

/* Aviso de segurança + link Coordenação */
#lock-screen .lock-sec-notice {
  text-align: center;
  font-size: .78rem;
  color: #94a3b8;
  display: flex;
  flex-direction: column;
  gap: 7px;
  margin-top: 0;
}

#lock-screen .lock-sec-notice a {
  color: #00a87d;
  font-weight: 600;
  text-decoration: none;
}

#lock-screen .lock-sec-notice a:hover {
  text-decoration: underline;
}

/* Erro de login */
#lock-screen .lock-err {
  color: #e53e3e;
  font-size: .82rem;
  text-align: center;
  margin-top: 10px;
  min-height: 0;
}

/* Ícone de olho (SVG) no campo senha */
#lock-screen .pass-eye {
  position: absolute;
  right: 13px;
  top: 50%;
  transform: translateY(-50%);
  cursor: pointer;
  color: #94a3b8;
  line-height: 0;
  padding: 4px;
  transition: color .2s;
}

#lock-screen .pass-eye:hover {
  color: #0097b2;
}

#lock-screen .pass-wrap .lock-input {
  padding-right: 46px;
}

/* Mobile */
@media (max-width: 500px) {
  #lock-screen .lock-card {
    padding: 26px 22px 22px;
    border-radius: 18px;
  }

  .lock-logo-box {
    width: 82px;
    height: 82px;
    border-radius: 20px;
  }

  .lock-logo-new {
    width: 66px;
    height: 66px;
  }

  .lock-brand-title {
    font-size: 1.2rem;
  }

  #lock-screen .lock-card-title {
    font-size: 1.55rem;
  }
}

/* ── DESKTOP: split screen, fundo escuro + card flutuante ── */
@media (min-width: 900px) {

  #lock-screen.lock-overlay {
    background: linear-gradient(135deg, #0b1d35 0%, #0d3858 38%, #0a5247 68%, #0c6e58 100%);
    padding: 0;
    overflow: hidden;
    align-items: stretch;
    justify-content: center;
  }

  /* Orbs decorativos flutuantes */
  #lock-screen.lock-overlay::before {
    content: '';
    position: absolute;
    width: 560px;
    height: 560px;
    background: radial-gradient(circle, rgba(0,210,140,0.13) 0%, transparent 65%);
    border-radius: 50%;
    top: -180px;
    left: -110px;
    pointer-events: none;
    animation: lockGlow 10s ease-in-out infinite alternate;
    z-index: 0;
  }

  #lock-screen.lock-overlay::after {
    content: '';
    position: absolute;
    width: 400px;
    height: 400px;
    background: radial-gradient(circle, rgba(0,140,200,0.10) 0%, transparent 65%);
    border-radius: 50%;
    bottom: -90px;
    left: 16%;
    pointer-events: none;
    animation: lockGlow 14s ease-in-out infinite alternate-reverse;
    z-index: 0;
  }

  @keyframes lockGlow {
    0%   { transform: translateY(0px)  scale(1);    }
    100% { transform: translateY(46px) scale(1.12); }
  }

  /* Layout de duas colunas a altura total */
  .lock-center-wrap {
    flex-direction: row;
    max-width: 100%;
    width: 100%;
    min-height: 100vh;
    align-items: stretch;
    gap: 0;
  }

  /* ┌─ Painel hero esquerdo ─┐ */
  .lock-brand {
    flex: 1;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: flex-start;
    padding: 64px 80px;
    margin-bottom: 0;
    text-align: left;
    position: relative;
    z-index: 1;
    overflow: hidden;
  }

  /* Linha separadora sutil entre os painéis */
  .lock-brand::after {
    content: '';
    position: absolute;
    right: 0;
    top: 10%;
    bottom: 10%;
    width: 1px;
    background: linear-gradient(to bottom, transparent, rgba(255,255,255,0.12), transparent);
    z-index: 0;
  }

  /* Logo com efeito glass morphism */
  .lock-logo-box {
    width: 118px;
    height: 118px;
    border-radius: 28px;
    background: rgba(255, 255, 255, 0.10);
    backdrop-filter: blur(12px);
    border: 1px solid rgba(255, 255, 255, 0.16);
    box-shadow: 0 16px 50px rgba(0, 0, 0, 0.32), inset 0 1px 0 rgba(255,255,255,0.10);
    margin: 0 0 32px 0;
  }

  .lock-logo-new {
    width: 94px;
    height: 94px;
  }

  /* Título e subtexto brancos */
  .lock-brand-title {
    font-size: 2.45rem;
    color: #ffffff;
    text-align: left;
    margin-bottom: 16px;
    letter-spacing: -0.4px;
    line-height: 1.18;
  }

  .lock-brand-green {
    color: #00e5a0;
  }

  .lock-brand-sub {
    font-size: 1rem;
    color: rgba(255, 255, 255, 0.62);
    max-width: 410px;
    margin: 0;
    text-align: left;
    line-height: 1.78;
  }

  /* Lista de features — visível somente no desktop */
  .lock-features {
    display: flex;
    flex-direction: column;
    gap: 14px;
    margin-top: 36px;
    list-style: none;
    padding: 0;
  }

  .lock-features li {
    display: flex;
    align-items: center;
    gap: 12px;
    font-size: 0.87rem;
    color: rgba(255, 255, 255, 0.68);
    font-family: var(--font-body);
  }

  .lock-feat-icon {
    display: flex;
    width: 24px;
    height: 24px;
    flex-shrink: 0;
    align-items: center;
    justify-content: center;
    background: rgba(0, 229, 160, 0.15);
    border: 1px solid rgba(0, 229, 160, 0.35);
    border-radius: 50%;
    font-size: 0.65rem;
    font-weight: 700;
    color: #00e5a0;
  }

  /* ┌─ Coluna direita com o card ─┐ */
  .lock-card-col {
    flex: 0 0 468px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 40px 48px;
    position: relative;
    z-index: 2;
  }

  /* Card flutuante com sombra imponente */
  #lock-screen .lock-card {
    max-width: 100%;
    width: 100%;
    box-shadow:
      0 36px 100px rgba(0, 0, 0, 0.55),
      0 0 0 1px rgba(255, 255, 255, 0.06),
      0 0 80px rgba(0, 197, 135, 0.07);
    animation: lockCardIn 0.7s cubic-bezier(0.16, 1, 0.3, 1);
  }

  @keyframes lockCardIn {
    from { opacity: 0; transform: translateX(44px) scale(0.96); }
    to   { opacity: 1; transform: translateX(0)    scale(1);    }
  }
}


/* ═══════════════════════════════════════════
   MODO APRESENTAÇÃO & PRINT  (v3 tema claro)
═══════════════════════════════════════════ */
.pres-overlay {
  position: fixed;
  inset: 0;
  z-index: 1000;
  background: #f1f5f9;
  color: #1e293b;
  display: none;
  flex-direction: column;
  overflow-y: auto;
}

.pres-hdr {
  position: sticky;
  top: 0;
  z-index: 10;
  background: rgba(255, 255, 255, .92);
  backdrop-filter: blur(16px);
  padding: 14px 28px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-bottom: 1px solid #e2e8f0;
}

/* ── Config view ── */
.pres-cat { margin-bottom: 24px; }
.pres-cat-hdr {
  font-size: 1rem; font-weight: 700; color: var(--em);
  margin-bottom: 10px; letter-spacing: .03em;
}
.pres-cat-list { display: flex; flex-direction: column; gap: 10px; }
.pres-item {
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 10px;
  padding: 14px 16px;
}
.pres-check-label {
  display: flex; align-items: center; gap: 10px;
  cursor: pointer; font-weight: 600; margin-bottom: 8px;
  color: #1e293b;
}
.pres-check-label input { width: 18px; height: 18px; accent-color: var(--em); }
.pres-item textarea {
  width: 100%; background: #f8fafc;
  border: 1px solid #e2e8f0; color: #334155;
  padding: 10px 12px; border-radius: 8px; font-size: .82rem;
  min-height: 48px; resize: vertical; font-family: var(--font-body);
}

/* ── Slides ── */
.pslide {
  min-height: 100vh;
  width: 100%;
  padding: 60px 48px 40px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  position: relative;
  border-bottom: 1px solid #e2e8f0;
}
.ps-page {
  position: absolute; bottom: 20px; right: 40px;
  color: #94a3b8; font-size: .75rem;
}

/* CAPA */
.pslide-cover {
  background: linear-gradient(160deg, #f8fafc 0%, #e2e8f0 50%, #f1f5f9 100%);
}
.ps-cover-bg {
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 70% 50% at 20% 30%, rgba(5,150,105,.06) 0%, transparent 60%),
    radial-gradient(ellipse 50% 40% at 80% 70%, rgba(37,99,235,.05) 0%, transparent 60%);
  pointer-events: none;
}
.ps-cover-content { position: relative; text-align: center; z-index: 1; }
.ps-cover-icon { font-size: 3.5rem; margin-bottom: 16px; }
.ps-cover-title {
  font-family: var(--font-head); font-size: clamp(2.5rem, 5vw, 4.5rem);
  font-style: italic; color: #0f172a; margin-bottom: 8px; line-height: 1.1;
}
.ps-cover-subtitle {
  font-size: 1.1rem; color: #64748b;
  letter-spacing: .08em; text-transform: uppercase;
}
.ps-cover-divider {
  width: 80px; height: 3px; background: var(--em);
  border-radius: 2px; margin: 32px auto;
}
.ps-cover-hosp {
  font-size: 1.5rem; font-weight: 700; color: var(--em);
  letter-spacing: .05em; text-transform: uppercase;
}
.ps-cover-detail { font-size: 1rem; color: #94a3b8; margin-top: 10px; }

/* RESUMO EXECUTIVO */
.ps-sec-title {
  font-family: var(--font-head); font-size: 2.4rem;
  font-style: italic; color: #0f172a; margin-bottom: 6px;
}
.ps-sec-sub {
  color: #64748b; font-size: .95rem; margin-bottom: 36px;
}
.ps-summary-grid {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 20px; width: 100%; max-width: 1100px;
}
.ps-summary-card {
  border-radius: 16px; padding: 28px 24px;
  text-align: center; border: 1px solid #e2e8f0;
  background: #fff;
  box-shadow: 0 1px 3px rgba(0,0,0,.06);
}
.ps-summary-card.p-good { background: #ecfdf5; border-color: #a7f3d0; }
.ps-summary-card.p-warn { background: #fffbeb; border-color: #fde68a; }
.ps-summary-card.p-bad  { background: #fef2f2; border-color: #fecaca; }
.ps-summary-card.p-neutral { background: #f8fafc; }
.ps-summary-card.p-blue { background: #eff6ff; border-color: #bfdbfe; }
.ps-sc-icon { font-size: 1.6rem; margin-bottom: 6px; }
.ps-sc-label {
  font-size: .72rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: .06em; color: #64748b; margin-bottom: 6px;
}
.ps-sc-val { font-size: 2.4rem; font-weight: 800; color: #0f172a; }
.ps-summary-card.p-good .ps-sc-val { color: #059669; }
.ps-summary-card.p-warn .ps-sc-val { color: #d97706; }
.ps-summary-card.p-bad  .ps-sc-val { color: #dc2626; }
.ps-sc-status { font-size: .72rem; color: #94a3b8; margin-top: 4px; }

/* KPI DETALHADO */
.ps-detail-grid {
  display: flex; flex-direction: column;
  gap: 20px; width: 100%; max-width: 960px;
}
.ps-kpi-card {
  border-radius: 14px; padding: 24px 28px;
  border: 1px solid #e2e8f0;
  border-left: 4px solid var(--blue);
  background: #fff;
  box-shadow: 0 1px 3px rgba(0,0,0,.05);
}
.ps-kpi-card.p-good { border-left-color: #059669; background: #f0fdf4; }
.ps-kpi-card.p-warn { border-left-color: #d97706; background: #fffbeb; }
.ps-kpi-card.p-bad  { border-left-color: #dc2626; background: #fef2f2; }
.ps-kpi-card.p-neutral { border-left-color: #cbd5e1; background: #f8fafc; }
.ps-kpi-card.p-blue { border-left-color: #3b82f6; background: #eff6ff; }
.ps-kpi-hdr {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 10px;
}
.ps-kpi-name {
  font-size: .85rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: .05em; color: #475569;
}
.ps-kpi-val { font-size: 2rem; font-weight: 800; color: #0f172a; }
.ps-kpi-card.p-good .ps-kpi-val { color: #059669; }
.ps-kpi-card.p-warn .ps-kpi-val { color: #d97706; }
.ps-kpi-card.p-bad .ps-kpi-val  { color: #dc2626; }
.ps-kpi-desc { font-size: .82rem; color: #64748b; line-height: 1.5; margin-bottom: 8px; }
.ps-kpi-formula {
  font-family: var(--font-mono); font-size: .75rem;
  padding: 8px 12px; border-radius: 8px;
  background: #ecfdf5; color: #047857; margin-bottom: 8px;
  border: 1px solid #a7f3d0;
}
.ps-kpi-formula span { color: #64748b; }
.ps-cuts { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 8px; }
.ps-cut-g { background: #d1fae5; color: #065f46; padding: 3px 10px; border-radius: 12px; font-size: .7rem; font-weight: 600; }
.ps-cut-y { background: #fef3c7; color: #92400e; padding: 3px 10px; border-radius: 12px; font-size: .7rem; font-weight: 600; }
.ps-cut-r { background: #fee2e2; color: #991b1b; padding: 3px 10px; border-radius: 12px; font-size: .7rem; font-weight: 600; }
.ps-kpi-ref { font-size: .7rem; color: #94a3b8; font-style: italic; margin-bottom: 8px; }
.ps-kpi-comment {
  padding: 12px 14px; margin-top: 4px;
  background: #f8fafc; border-radius: 8px;
  font-size: .88rem; color: #334155;
  line-height: 1.5; white-space: pre-wrap;
  border-left: 3px solid var(--em);
}

/* TREND */
.p-trend { font-size: 1.2rem; font-weight: 800; }
.p-trend-up { color: #059669; }
.p-trend-down { color: #dc2626; }
.p-trend-flat { color: #94a3b8; }

/* CHARTS */
.ps-chart-title {
  font-family: var(--font-head); font-size: 2rem;
  font-style: italic; color: #0f172a; margin-bottom: 4px;
}
.ps-chart-desc { color: #64748b; font-size: .88rem; margin-bottom: 28px; max-width: 800px; text-align: center; }
.ps-chart-box {
  width: 100%; max-width: 1000px; height: 380px;
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 14px; padding: 24px;
  box-shadow: 0 1px 3px rgba(0,0,0,.05);
}
.ps-chart-meta {
  margin-top: 20px; max-width: 800px; text-align: left;
  display: flex; flex-direction: column; gap: 6px;
}
.ps-cm-formula {
  font-family: var(--font-mono); font-size: .78rem;
  color: #047857; padding: 8px 14px; border-radius: 8px;
  background: #ecfdf5; border: 1px solid #a7f3d0;
}
.ps-cm-formula strong { color: #64748b; }
.ps-cm-ref { font-size: .72rem; color: #94a3b8; font-style: italic; padding: 0 4px; }

/* SLIDE FINAL */
.pslide-end { padding-bottom: 80px; }
.ps-end-grid {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 28px; width: 100%; max-width: 960px;
}
.ps-end-col {
  border-radius: 16px; padding: 28px;
  border: 1px solid #e2e8f0;
  background: #fff;
  box-shadow: 0 1px 3px rgba(0,0,0,.05);
}
.ps-end-good { background: #f0fdf4; border-color: #a7f3d0; }
.ps-end-bad  { background: #fef2f2; border-color: #fecaca; }
.ps-end-icon { font-size: 2rem; margin-bottom: 10px; }
.ps-end-col h3 {
  font-family: var(--font-head); font-size: 1.4rem;
  font-style: italic; color: #0f172a; margin-bottom: 14px;
}
.ps-end-col ul { list-style: none; padding: 0; }
.ps-end-col li {
  padding: 6px 0; font-size: .88rem;
  color: #334155; border-bottom: 1px solid #f1f5f9;
}
.ps-end-col li::before { content: '• '; color: #94a3b8; }
.ps-end-col p { color: #94a3b8; font-size: .88rem; }
.ps-end-footer {
  margin-top: 48px; text-align: center;
  color: #94a3b8; font-size: .78rem;
}
.ps-end-footer strong { color: var(--em); }

/* ── PRINT ── */
@media print {
  body * { display: none !important; }
  .pres-overlay, .pres-overlay * {
    display: flex !important;
    color: #1e293b !important;
  }
  .pres-overlay { position: static !important; background: white !important; overflow: visible !important; }
  .pslide { page-break-after: always; min-height: 0; padding: 30px; border: none !important; display: block !important; }
  .pres-hdr, .ps-page, #btn-exit-pres { display: none !important; }
  .pslide-cover { background: white !important; }
  .ps-cover-bg { display: none !important; }
  canvas { max-width: 100% !important; height: auto !important; }
}

@media (max-width: 700px) {
  .pslide { padding: 32px 16px 24px; }
  .ps-summary-grid { grid-template-columns: 1fr; }
  .ps-end-grid { grid-template-columns: 1fr; }
  .ps-chart-box { height: 260px; padding: 12px; }
  .ps-cover-title { font-size: 2rem !important; }
  .ps-sec-title { font-size: 1.6rem; }
  .pres-hdr { padding: 10px 14px; }
}

/* ═══════════════════════════════════════════
   VALIDAÇÃO EM TEMPO REAL
═══════════════════════════════════════════ */
.fcell.v-error { border-color: var(--red) !important; background: var(--red-dim) !important; }
.fcell.v-warn  { border-color: var(--amber) !important; background: rgba(245,166,35,0.05) !important; }
.fcell-computed { pointer-events:none; background: rgba(39, 174, 96, 0.07); border-color: rgba(39, 174, 96, 0.3) !important; border-radius: 6px; }
.fcell-computed label { color: #27ae60; font-weight: 600; }
.sval-computed  { cursor:default; color: #27ae60 !important; font-weight: 600; background: transparent; }
.computed-tag   { font-size:.55rem; background:rgba(39,174,96,0.15); color:#27ae60; padding:1px 5px; border-radius:3px; margin-left:6px; text-transform:uppercase; font-weight:700; letter-spacing:.04em; }

#validation-banner { display:none; max-width:700px; margin:0 auto 16px; padding:16px; border-radius:var(--r-md); }
#validation-banner[data-show] { display:block; }

.vb-section { margin-bottom:8px; padding:12px; border-radius:var(--r-sm); }
.vb-section:last-child { margin-bottom:0; }
.vb-errors { color:var(--red); background:var(--red-dim); border:1px solid rgba(220,38,38,0.3); }
.vb-warns  { color:var(--amber); background:rgba(245,166,35,0.08); border:1px solid rgba(245,166,35,0.3); }
.vb-section ul { margin:4px 0 0 16px; padding:0; font-size:.82rem; line-height:1.6; }
.vb-section strong { font-size:.8rem; text-transform:uppercase; letter-spacing:.04em; }

/* ═══════════════════════════════════════════
   SPARKLINES NOS KPI CARDS
═══════════════════════════════════════════ */
.kcard-spark { position:absolute; bottom:6px; left:8px; right:8px; width:calc(100% - 16px); opacity:.6; }
.kcard:hover .kcard-spark { opacity:.9; }

/* ═══════════════════════════════════════════
   DICIONÁRIO DINÂMICO
═══════════════════════════════════════════ */
.dict-entry { margin-bottom:12px; padding-bottom:12px; border-bottom:1px solid var(--border); }
.dict-entry h4 { color:var(--em); font-size:.9rem; margin-bottom:4px; }
.dict-entry p { font-size:.82rem; color:var(--text2); margin-bottom:4px; }
.dict-entry code { display:block; font-size:.8rem; background:var(--surface2); padding:6px 10px; border-radius:4px; margin-bottom:6px; border:1px solid var(--border); white-space:pre-wrap; word-break:break-word; }
.dict-entry-card { margin-bottom:12px; }
.dict-cutoff { margin-top:8px; font-size:.8rem; }
.dict-ref { margin-top:6px; font-size:.78rem; color:var(--text3); font-style:italic; }

/* Pílulas de ponto de corte — dicionário */
.dc-pill { display:inline-block; padding:2px 8px; border-radius:10px; font-size:.72rem; font-weight:600; margin:0 4px; }
.dc-good { background:rgba(0,229,160,.15); color:var(--em); }
.dc-bad  { background:var(--red-dim); color:var(--red); }
.dc-warn { background:rgba(245,166,35,.15); color:var(--amber); }

/* Pílulas de ponto de corte — tooltip popup */
.fp-cutoff { margin-top:8px; font-size:.72rem; line-height:1.8; }
.fp-cut-good { background:rgba(0,229,160,.2); color:#00e5a0; padding:1px 6px; border-radius:8px; margin:0 3px; }
.fp-cut-bad  { background:rgba(255,77,106,.2); color:#ff4d6a; padding:1px 6px; border-radius:8px; margin:0 3px; }
.fp-cut-warn { background:rgba(245,166,35,.2); color:#f5a623; padding:1px 6px; border-radius:8px; margin:0 3px; }

/* ═══════════════════════════════════════════
   MOBILE UX IMPROVEMENTS
═══════════════════════════════════════════ */
@media (max-width: 600px) {
  /* Touch targets maiores — WCAG recomenda mínimo 44px, 48px é ideal para luvas */
  .sbtn { width:48px; height:48px; font-size:1.4rem; }
  .sval { font-size:1.2rem; padding:6px 4px; min-width:48px; }
  .fcell { padding:10px 12px; }
  .fcell label { font-size:.70rem; }

  /* Save bar fixo no bottom para acesso rapido */
  .save-bar {
    position:sticky; bottom:0; z-index:50;
    background:var(--surface); border-top:2px solid var(--em);
    box-shadow:0 -4px 20px rgba(0,0,0,.1);
    padding:10px 16px;
  }

  /* KPI cards mais compactos */
  .kpi-grid { gap:8px; grid-template-columns:repeat(auto-fill, minmax(140px, 1fr)); }
  .kcard { padding:12px 10px; }
  .kval { font-size:1.3rem !important; }
  .klabel { font-size:.6rem; }
  .ksub { font-size:.55rem; }

  /* Validation banner full-width */
  #validation-banner { margin:0 8px 12px; padding:12px; }
  .vb-section ul { font-size:.75rem; }

  /* Charts mais compactos */
  .chart-wrap { height:200px; }
  .ccard { padding:14px 12px; }

  /* Mapa de mobilização mobile */
  .mapa-leitos-grid { grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); }
  .leito-card { padding: 10px 10px; }
  .leito-nome { font-size: .65rem; }
  .leito-acoes { flex-direction: column; }
  .leito-btn { font-size: .58rem; padding: 4px 8px; text-align: center; }
}
/* ═══════════════════════════════════════════
   DASHBOARD TAB NAVIGATION
═══════════════════════════════════════════ */
.dash-tab-nav {
  display: flex;
  align-items: center;
  gap: 0;
  margin: 16px 0 8px;
  position: relative;
}
.dash-tab-btns {
  display: flex;
  gap: 6px;
  overflow-x: auto;
  scroll-behavior: smooth;
  flex: 1;
  padding: 4px 2px;
  -ms-overflow-style: none;
  scrollbar-width: none;
}
.dash-tab-btns::-webkit-scrollbar { display: none; }
.dash-tab-btn {
  flex-shrink: 0;
  padding: 10px 18px;
  border: 1.5px solid var(--border2);
  border-radius: 10px;
  background: var(--surface);
  color: var(--text2);
  font-size: .82rem;
  font-weight: 600;
  cursor: pointer;
  transition: all .25s ease;
  white-space: nowrap;
  font-family: var(--font-body);
  letter-spacing: .01em;
}
.dash-tab-btn:hover {
  border-color: var(--em);
  color: var(--em);
  background: var(--em-dim);
}
.dash-tab-btn.active {
  background: var(--em);
  color: #fff;
  border-color: var(--em);
  box-shadow: 0 2px 12px rgba(5,150,105,.25);
}
.dash-tab-arrow {
  flex-shrink: 0;
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1.5px solid var(--border2);
  border-radius: 50%;
  background: var(--surface);
  color: var(--text2);
  font-size: 1.3rem;
  font-weight: 700;
  cursor: pointer;
  transition: all .2s ease;
  line-height: 1;
}
.dash-tab-arrow:hover {
  border-color: var(--em);
  color: var(--em);
  background: var(--em-dim);
}
.dash-tab-arrow-left { margin-right: 8px; }
.dash-tab-arrow-right { margin-left: 8px; }
.dash-tab-content {
  display: none;
  animation: dtabFadeIn .3s ease;
  max-width: 100%;
  width: 100%;
  min-width: 0;
  box-sizing: border-box;
}
.dash-tab-content.active {
  display: block;
}
@keyframes dtabFadeIn {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}

@media (max-width: 600px) {
  .dash-tab-btn { padding: 8px 12px; font-size: .72rem; }
  .dash-tab-arrow { width: 30px; height: 30px; font-size: 1.1rem; }
}