/* ════════════════════════════════════════════════════════════════════════
   site.css — layout do shell + telas. Estética: base branca, índigo SEMAS,
   botões circulares, listas limpas (inspirado no Coinbase).
   ════════════════════════════════════════════════════════════════════════ */

/* Nova entrada é full-screen por tela → esconde a chrome genérica do shell.
   (O shell de servidor com tab-bar própria entra na Etapa 2.) */
app-topbar, app-bottom-nav, app-footer { display: none; }

#app-root { min-height: 100dvh; }

/* ════════════════ CONTAINER ════════════════ */
.container { width: 100%; max-width: 1120px; margin: 0 auto; padding: 0 var(--space-4); }
@media (min-width: 768px) { .container { padding: 0 var(--space-6); } }
.page { padding: var(--space-6) 0 var(--space-10); }

/* ════════════════ SPLASH ════════════════ */
.splash {
  position: fixed; inset: 0; z-index: var(--z-toast);
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  background: var(--brand-700); color: var(--neutral-0);
  opacity: 1; transition: opacity var(--duration-slow) var(--ease);
  pointer-events: none;   /* puramente visual — nunca engole clique do usuário */
}
.splash.is-hidden { opacity: 0; pointer-events: none; }
.splash__inner { display: flex; flex-direction: column; align-items: center; gap: var(--space-3); animation: splash-pop var(--duration-slow) var(--ease-out); }
.splash__logo { width: 172px; height: 172px; object-fit: contain; padding: 22px; background: #fff; border-radius: var(--radius-full); box-shadow: 0 16px 40px rgba(0,0,0,0.38); }
.splash__brand { font-size: var(--text-4xl); font-weight: var(--fw-bold); letter-spacing: var(--tracking-tighter); margin-top: var(--space-2); }
.splash__tagline { font-size: var(--text-base); font-weight: var(--fw-medium); color: rgba(245,245,245,0.72); letter-spacing: var(--tracking-tight); }
.splash__bar { width: 120px; height: 4px; border-radius: var(--radius-full); background: rgba(255,255,255,0.25); overflow: hidden; }
.splash__bar-fill { display: block; height: 100%; width: 40%; background: var(--neutral-0); border-radius: var(--radius-full); animation: splash-load 1.3s var(--ease) infinite; }
@keyframes splash-pop { from { opacity: 0; transform: scale(0.92); } to { opacity: 1; transform: scale(1); } }
@keyframes splash-load { 0% { transform: translateX(-120%); } 100% { transform: translateX(320%); } }

/* ════════════════ WELCOME (boas-vindas) ════════════════ */
.welcome { display: flex; flex-direction: column; min-height: 100dvh; max-width: 520px; margin: 0 auto; padding: calc(var(--space-6) + var(--safe-top)) var(--space-6) calc(var(--space-6) + var(--safe-bottom)); }
.welcome__art { position: relative; display: flex; align-items: center; justify-content: center; height: 168px; margin-top: var(--space-2); }
.welcome__art img { max-width: 100%; max-height: 158px; object-fit: contain; }
.welcome__spark { position: absolute; color: var(--brand-500); }
.welcome__spark--1 { top: 6px; left: 8%; }
.welcome__spark--2 { top: 28px; right: 12%; color: var(--warning); }
.welcome__spark--3 { bottom: 6px; left: 22%; color: var(--success); }
.welcome__title { font-size: clamp(var(--text-3xl), 8vw, var(--text-4xl)); font-weight: var(--fw-bold); letter-spacing: var(--tracking-tighter); line-height: 1.08; margin-top: var(--space-4); }
.welcome__sub { font-size: var(--text-base); color: var(--text-secondary); margin-top: var(--space-3); }
.welcome__divider { height: 1px; background: var(--border); margin: var(--space-6) 0; }
.welcome__actions { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-4); }
.welcome__foot { margin-top: auto; padding-top: var(--space-6); }

/* ════════════════ LANDING v2 (porta de entrada — navy Remo) ════════════════
   Conteúdo vem do Repo (config editável no Admin). Seções: nav · hero · cards ·
   números · vídeo · mapa · rodapé. Recriado em vanilla a partir de refs do 21st.dev. */
.lp { position: relative; background: var(--bg); }
.lp-sec { width: 100%; max-width: 1120px; margin: 0 auto; padding: var(--space-16) var(--space-5); scroll-margin-top: 80px; }

/* ── NAV (desktop: barra horizontal · mobile: marca + hambúrguer) ── */
.lp-nav {
  position: sticky; top: 0; z-index: var(--z-dropdown);
  display: flex; align-items: center; justify-content: space-between; gap: var(--space-4);
  padding: calc(var(--space-3) + var(--safe-top)) var(--space-5) var(--space-3);
  background: rgba(5,11,24,0.50); backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--border-subtle);
  transition: box-shadow var(--duration) var(--ease), background var(--duration) var(--ease);
}
.lp-nav.is-scrolled { box-shadow: var(--shadow-md); background: rgba(5,11,24,0.72); }
.lp-brand { display: inline-flex; align-items: center; gap: var(--space-3); min-width: 0; }
.lp-brand__logo { height: 46px; width: auto; object-fit: contain; display: block; }
.lp-brand__text { display: flex; flex-direction: column; line-height: 1.1; min-width: 0; }
.lp-brand__name { font-size: var(--text-2xl); font-weight: var(--fw-bold); letter-spacing: 0.01em; color: #fff; }
.lp-brand__tag { font-size: 11px; color: var(--text-secondary); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

.lp-nav__menu { display: none; align-items: center; gap: var(--space-6); list-style: none; margin: 0; padding: 0; }
.lp-nav__link {
  position: relative; font-size: var(--text-sm); font-weight: var(--fw-medium);
  color: var(--text-secondary); transition: color var(--duration-fast) var(--ease);
}
.lp-nav__link:hover { color: var(--text); }
.lp-nav__link.is-active { color: var(--text); }
.lp-nav__link.is-active::after {
  content: ''; position: absolute; left: 0; right: 0; bottom: -6px; height: 2px;
  background: var(--text); border-radius: var(--radius-full);
}
.lp-nav__actions { display: flex; align-items: center; gap: var(--space-3); flex: none; }
.lp-nav__logo2 { display: none; height: 56px; width: auto; object-fit: contain; }
.lp-nav__signin {
  display: none; align-items: center; gap: var(--space-2);
  padding: 8px var(--space-4);
  font-size: var(--text-sm); font-weight: var(--fw-medium); color: var(--text);
  border: 1px solid var(--border-strong); border-radius: var(--radius-full);
  transition: background var(--duration-fast) var(--ease), border-color var(--duration-fast) var(--ease);
}
.lp-nav__signin:hover { background: rgba(245,245,245,0.06); border-color: var(--text-subtle); }
.lp-nav__cta { display: none; }
.lp-burger {
  display: inline-flex; align-items: center; justify-content: center;
  width: 44px; height: 44px; border: 1px solid var(--border-strong);
  background: rgba(245,245,245,0.04); border-radius: var(--radius-md); color: var(--text); cursor: pointer;
}

/* ── GAVETA mobile ── */
.lp-drawer { position: fixed; inset: 0; z-index: var(--z-modal); }
.lp-drawer[hidden] { display: none; }
.lp-drawer__backdrop { position: absolute; inset: 0; background: rgba(5,11,24,0.6); opacity: 0; transition: opacity var(--duration) var(--ease); }
.lp-drawer.is-open .lp-drawer__backdrop { opacity: 1; }
.lp-drawer__panel {
  position: absolute; top: 0; right: 0; height: 100%; width: min(82vw, 320px);
  display: flex; flex-direction: column; gap: var(--space-2);
  padding: calc(var(--space-5) + var(--safe-top)) var(--space-5) calc(var(--space-6) + var(--safe-bottom));
  background: var(--bg-muted); border-left: 1px solid var(--border);
  transform: translateX(100%); transition: transform var(--duration) var(--ease); box-shadow: var(--shadow-xl);
}
.lp-drawer.is-open .lp-drawer__panel { transform: translateX(0); }
.lp-drawer__head { display: flex; align-items: center; justify-content: space-between; margin-bottom: var(--space-4); }
.lp-drawer__x { display: inline-flex; width: 40px; height: 40px; align-items: center; justify-content: center; background: none; border: none; color: var(--text-secondary); cursor: pointer; }
.lp-drawer__menu { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; }
.lp-drawer__link { display: block; padding: var(--space-4) 0; font-size: var(--text-lg); font-weight: var(--fw-medium); color: var(--text); border-bottom: 1px solid var(--border); }
.lp-drawer__ctas { display: flex; flex-direction: column; gap: var(--space-3); margin-top: var(--space-6); }

/* ── HERO (menor que antes; slogan grande no desktop) ── */
.lp-hero {
  position: relative; overflow: hidden;
  min-height: clamp(480px, 72vh, 720px);
  display: flex; align-items: center; justify-content: center;
  padding: var(--space-12) var(--space-5) var(--space-16); text-align: center;
  scroll-margin-top: 80px;
}
.lp__dots { position: absolute; inset: 0; z-index: 0; }
.lp-hero__mascote {
  position: absolute; right: -8%; bottom: -6%; width: min(78%, 460px); height: auto;
  opacity: 0.06; filter: grayscale(1) brightness(1.7); z-index: 0; pointer-events: none; user-select: none;
}
.lp-hero__veil {
  position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background:
    radial-gradient(ellipse 78% 56% at 50% 38%, transparent 0%, rgba(8,17,38,0.55) 82%),
    linear-gradient(to bottom, transparent 62%, var(--bg) 99%);
}
.lp-hero__inner { position: relative; z-index: 2; max-width: 860px; margin: 0 auto; }
.lp-hero__brand { display: flex; justify-content: center; margin-bottom: var(--space-6); }
.lp-hero__logo { width: min(72vw, 360px); height: auto; object-fit: contain; display: block; filter: drop-shadow(0 6px 18px rgba(0,0,0,0.35)); }
.lp-badge {
  display: inline-flex; align-items: center; gap: var(--space-2);
  margin-bottom: var(--space-6); padding: 6px var(--space-4);
  font-size: var(--text-xs); font-weight: var(--fw-medium); color: var(--text-secondary);
  background: rgba(245,245,245,0.04); border: 1px solid var(--border-strong); border-radius: var(--radius-full); backdrop-filter: blur(4px);
}
.lp-badge__dot { width: 7px; height: 7px; border-radius: var(--radius-full); background: var(--success); animation: lp-pulse 2.4s var(--ease) infinite; }
@keyframes lp-pulse {
  0%   { box-shadow: 0 0 0 0 rgba(52,211,153,0.5); }
  70%  { box-shadow: 0 0 0 8px rgba(52,211,153,0); }
  100% { box-shadow: 0 0 0 0 rgba(52,211,153,0); }
}
.lp-hero__title {
  font-size: clamp(var(--text-4xl), 8vw, 78px);
  font-weight: var(--fw-bold); letter-spacing: var(--tracking-tighter);
  line-height: 1.04; color: var(--text-secondary);
}
.lp-rotor { display: inline-block; overflow: hidden; vertical-align: bottom; }
.lp-word { display: inline-block; color: var(--text); transition: transform 300ms var(--ease), opacity 300ms var(--ease); }
.lp-word.is-out { transform: translateY(-110%); opacity: 0; }
.lp-word.is-in  { transform: translateY(110%);  opacity: 0; transition: none; }
.lp-hero__sub { max-width: 560px; margin: var(--space-5) auto 0; font-size: var(--text-base); color: var(--text-muted); line-height: 1.6; }
.lp-hero__cta { display: flex; flex-direction: column; gap: var(--space-3); width: 100%; max-width: 340px; margin: var(--space-8) auto 0; }

/* ── SEÇÕES: cabeçalho comum ── */
.lp-sec__head { display: flex; align-items: flex-end; justify-content: space-between; gap: var(--space-4); margin-bottom: var(--space-8); }
.lp-sec__head--center { justify-content: center; text-align: center; }
.lp-sec__title { font-size: clamp(var(--text-2xl), 5vw, var(--text-4xl)); font-weight: var(--fw-bold); letter-spacing: var(--tracking-tight); color: var(--text); }
.lp-sec__desc { margin-top: var(--space-2); max-width: 520px; font-size: var(--text-base); color: var(--text-muted); line-height: 1.55; }

/* ── CARDS (carrossel horizontal — estilo Gallery4) ── */
.lp-cards__nav { display: none; gap: var(--space-2); flex: none; }
.lp-cards__btn {
  display: inline-flex; width: 42px; height: 42px; align-items: center; justify-content: center;
  border: 1px solid var(--border-strong); background: var(--bg-muted); color: var(--text); border-radius: var(--radius-full); cursor: pointer;
  transition: background var(--duration-fast) var(--ease);
}
.lp-cards__btn:hover { background: var(--bg-subtle); }
.lp-cards__btn:disabled { opacity: 0.3; cursor: default; }
.lp-cards__viewport { overflow-x: auto; scrollbar-width: none; -ms-overflow-style: none; margin: 0 calc(-1 * var(--space-5)); padding: 0 var(--space-5) var(--space-2); cursor: grab; }
.lp-cards__viewport.is-dragging { cursor: grabbing; }
.lp-cards__viewport.is-dragging .lp-card { pointer-events: none; }
.lp-cards__viewport::-webkit-scrollbar { display: none; }
.lp-cards__track { display: flex; gap: var(--space-4); }
.lp-card {
  flex: 0 0 auto; width: 280px;
  display: flex; flex-direction: column; overflow: hidden;
  background: var(--bg-muted); border: 1px solid var(--border); border-radius: var(--radius-2xl);
  transition: transform var(--duration) var(--ease), border-color var(--duration) var(--ease);
}
.lp-card:hover { transform: translateY(-4px); border-color: var(--border-strong); }
.lp-card__media {
  height: 132px; display: flex; align-items: center; justify-content: center;
  background: radial-gradient(120% 120% at 30% 20%, #223153 0%, var(--brand-700) 80%);
  border-bottom: 1px solid var(--border);
}
.lp-card__media.has-img { background-size: cover; background-position: center; }
.lp-card__icon { width: 44px; height: 44px; color: var(--text); }
.lp-card__body { display: flex; flex-direction: column; gap: var(--space-2); padding: var(--space-5); flex: 1; }
.lp-card__title { font-size: var(--text-lg); font-weight: var(--fw-semibold); color: var(--text); }
.lp-card__desc { font-size: var(--text-sm); color: var(--text-muted); line-height: 1.5; flex: 1; }
.lp-card__cta { display: inline-flex; align-items: center; gap: var(--space-1); margin-top: var(--space-2); font-size: var(--text-sm); font-weight: var(--fw-medium); color: var(--text); }

/* ── CARD PRINCIPAL (feature) Cad Único ── */
.lp-feature {
  display: grid; grid-template-columns: 1fr; overflow: hidden;
  margin-bottom: var(--space-12);
  background: var(--bg-muted); border: 1px solid var(--border-strong); border-radius: var(--radius-3xl);
  box-shadow: var(--shadow-lg);
}
.lp-feature__media {
  min-height: 180px;
  background: radial-gradient(120% 120% at 30% 20%, #223153 0%, var(--brand-700) 80%);
}
.lp-feature__media.has-img { background-size: cover; background-position: center; }
.lp-feature__body { display: flex; flex-direction: column; align-items: flex-start; gap: var(--space-3); padding: var(--space-8); }
.lp-feature__eyebrow { font-size: var(--text-sm); font-weight: var(--fw-medium); letter-spacing: var(--tracking-wide); text-transform: uppercase; color: var(--text-secondary); }
.lp-feature__title { font-size: clamp(var(--text-3xl), 6vw, var(--text-5xl)); font-weight: var(--fw-bold); letter-spacing: var(--tracking-tighter); color: var(--text); }
.lp-feature__desc { max-width: 52ch; font-size: var(--text-base); color: var(--text-muted); line-height: 1.6; }
.lp-feature .btn { margin-top: var(--space-2); }
@media (min-width: 760px) { .lp-feature { grid-template-columns: 1fr 1fr; } }

/* ── card "Em breve" (serviço ainda não disponível) ── */
.lp-card__media { position: relative; }
.lp-card__badge {
  position: absolute; top: var(--space-3); right: var(--space-3);
  padding: 2px var(--space-2);
  font-size: var(--text-xs); font-weight: var(--fw-medium); letter-spacing: var(--tracking-wide); text-transform: uppercase;
  color: var(--text-secondary); background: rgba(8,17,38,0.72); border: 1px solid var(--border-strong); border-radius: var(--radius-full);
}
.lp-card--soon { opacity: 0.6; }
.lp-card--soon:hover { transform: none; border-color: var(--border); }
.lp-card__cta--soon { color: var(--text-subtle); cursor: default; }

/* ── NÚMEROS ── */
.lp-stats { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--space-4); }
.lp-stat { display: flex; flex-direction: column; align-items: center; text-align: center; gap: var(--space-1); padding: var(--space-6) var(--space-4); background: var(--bg-muted); border: 1px solid var(--border); border-radius: var(--radius-xl); }
.lp-stat__num { font-size: clamp(var(--text-3xl), 7vw, var(--text-5xl)); font-weight: var(--fw-bold); letter-spacing: var(--tracking-tighter); color: var(--text); }
.lp-stat__label { font-size: var(--text-sm); color: var(--text-muted); }

/* ── VÍDEO ── */
.lp-video__card {
  position: relative; display: block; width: 100%; aspect-ratio: 16 / 9; overflow: hidden; cursor: pointer;
  border: 1px solid var(--border); border-radius: var(--radius-3xl); padding: 0;
  background: linear-gradient(135deg, #16213c 0%, var(--brand-700) 70%); background-size: cover; background-position: center;
}
.lp-video__card.has-poster { background-color: var(--brand-700); }
.lp-video__card.has-poster::after { content: ''; position: absolute; inset: 0; background: linear-gradient(to top, rgba(5,11,24,0.72) 0%, rgba(8,17,38,0.22) 55%, rgba(8,17,38,0.1) 100%); z-index: 1; }
.lp-video__card.has-poster .lp-video__mascote { display: none; }
.lp-video__mascote { position: absolute; right: -4%; bottom: -8%; width: min(46%, 320px); opacity: 0.10; filter: grayscale(1) brightness(1.6); pointer-events: none; }
.lp-video__play {
  z-index: 2;
  position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%);
  display: inline-flex; align-items: center; justify-content: center; width: 78px; height: 78px;
  background: rgba(245,245,245,0.94); color: var(--brand-700); border-radius: var(--radius-full);
  box-shadow: var(--shadow-lg); transition: transform var(--duration) var(--ease);
}
.lp-video__card:hover .lp-video__play { transform: translate(-50%, -50%) scale(1.08); }
.lp-video__cap { z-index: 2; position: absolute; left: 0; right: 0; bottom: 0; display: flex; flex-direction: column; gap: 2px; padding: var(--space-6); text-align: left; background: linear-gradient(to top, rgba(5,11,24,0.85), transparent); }
.lp-video__cap-title { font-size: var(--text-lg); font-weight: var(--fw-semibold); color: var(--text); }
.lp-video__cap-desc { font-size: var(--text-sm); color: var(--text-secondary); }

/* ── MAPA ── */
.lp-map__grid { display: grid; grid-template-columns: 1fr; gap: var(--space-5); }
.lp-map__frame { overflow: hidden; border: 1px solid var(--border); border-radius: var(--radius-2xl); aspect-ratio: 16 / 11; background: var(--bg-muted); }
.lp-map__frame iframe { width: 100%; height: 100%; border: 0; display: block; filter: grayscale(0.2) contrast(1.05); }
.lp-map__info { display: flex; flex-direction: column; gap: var(--space-5); justify-content: center; }
.lp-map__list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: var(--space-4); }
.lp-map__list li { display: flex; align-items: flex-start; gap: var(--space-3); font-size: var(--text-base); color: var(--text-secondary); line-height: 1.5; }
.lp-map__list .icon { color: var(--text-muted); flex: none; margin-top: 2px; }
.lp-map__tel { color: var(--text); font-weight: var(--fw-medium); }
.lp-map__tel:hover { text-decoration: underline; }
.lp-map__actions { display: flex; flex-wrap: wrap; gap: var(--space-3); }

/* ── RODAPÉ institucional ── */
.lp-foot { position: relative; overflow: hidden; display: flex; flex-direction: column; align-items: center; gap: var(--space-2); padding: var(--space-10) var(--space-5) calc(var(--space-10) + var(--safe-bottom)); border-top: 1px solid var(--border); text-align: center; }
.lp-foot__mascote { position: absolute; right: -3%; bottom: -36%; width: min(42%, 280px); opacity: 0.06; filter: grayscale(1) brightness(1.7); pointer-events: none; user-select: none; z-index: 0; }
.lp-foot__crest { display: inline-flex; align-items: center; justify-content: center; width: 132px; height: 132px; margin-bottom: var(--space-4); border-radius: var(--radius-full); background: #fff; box-shadow: var(--shadow-lg); }
.lp-foot__brasao { height: 116px; width: auto; object-fit: contain; display: block; }
.lp-foot__crest, .lp-foot__inst, .lp-foot__sig { position: relative; z-index: 1; }
.lp-foot__inst { font-size: var(--text-base); font-weight: var(--fw-medium); color: var(--text); }
.lp-foot__sig { font-size: var(--text-xs); color: var(--text-muted); }

/* ── MODAL de vídeo ── */
.lp-vmodal { position: fixed; inset: 0; z-index: var(--z-modal); display: flex; align-items: center; justify-content: center; padding: var(--space-5); }
.lp-vmodal__backdrop { position: absolute; inset: 0; background: rgba(5,11,24,0.82); opacity: 0; transition: opacity var(--duration) var(--ease); }
.lp-vmodal.is-open .lp-vmodal__backdrop { opacity: 1; }
.lp-vmodal__box { position: relative; width: min(960px, 100%); transform: scale(0.96); opacity: 0; transition: transform var(--duration) var(--ease), opacity var(--duration) var(--ease); }
.lp-vmodal.is-open .lp-vmodal__box { transform: scale(1); opacity: 1; }
.lp-vmodal__x { position: absolute; top: -48px; right: 0; display: inline-flex; width: 40px; height: 40px; align-items: center; justify-content: center; background: rgba(245,245,245,0.08); border: 1px solid var(--border-strong); border-radius: var(--radius-full); color: var(--text); cursor: pointer; }
.lp-vmodal__frame { aspect-ratio: 16 / 9; overflow: hidden; border-radius: var(--radius-xl); background: #000; }
.lp-vmodal__frame iframe { width: 100%; height: 100%; border: 0; }
.lp-vmodal__soon { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: var(--space-2); aspect-ratio: 16 / 9; background: var(--bg-muted); border: 1px solid var(--border); border-radius: var(--radius-xl); color: var(--text-secondary); text-align: center; padding: var(--space-6); }
.lp-vmodal__soon p { font-size: var(--text-lg); font-weight: var(--fw-medium); color: var(--text); }
.lp-vmodal__soon span { font-size: var(--text-sm); color: var(--text-muted); }

/* ── Editor da Página Inicial (admin) ── */
.lpedit__row { display: flex; flex-direction: column; gap: var(--space-1); margin-bottom: var(--space-3); }
.lpedit__label { font-size: var(--text-sm); font-weight: var(--fw-medium); color: var(--text-secondary); }
.lpedit__group { padding: var(--space-4); margin-bottom: var(--space-3); background: var(--bg-muted); border: 1px solid var(--border); border-radius: var(--radius-lg); }
.lpedit__group-title { display: block; font-size: var(--text-sm); font-weight: var(--fw-semibold); color: var(--text); margin-bottom: var(--space-3); }
.lpedit__group-head { display: flex; align-items: center; justify-content: space-between; gap: var(--space-2); margin-bottom: var(--space-3); }
.lpedit__group-head .lpedit__group-title { margin-bottom: 0; }
.lpedit__remove { display: inline-flex; align-items: center; gap: var(--space-1); background: none; border: none; cursor: pointer; padding: var(--space-1) var(--space-2); border-radius: var(--radius-md); font-size: var(--text-sm); font-weight: var(--fw-medium); color: var(--danger); }
.lpedit__remove:hover { background: var(--danger-bg); }
.lpedit__add { margin-bottom: var(--space-3); }
.lpedit__actions { display: flex; flex-direction: column; gap: var(--space-3); margin: var(--space-6) 0 var(--space-10); }

/* Seletor de foto (Admin → Site): preview + enviar/tirar foto + colar link */
.imgpick { display: flex; gap: var(--space-3); align-items: flex-start; }
.imgpick__prev { flex: 0 0 88px; width: 88px; height: 88px; border-radius: var(--radius-lg); border: 1px dashed var(--border); background: var(--bg-muted) center/cover no-repeat; display: flex; align-items: center; justify-content: center; color: var(--text-secondary); overflow: hidden; }
.imgpick__prev.has-img { border-style: solid; }
.imgpick__prev .icon { width: 28px; height: 28px; opacity: .5; }
.imgpick__side { flex: 1 1 auto; display: flex; flex-direction: column; gap: var(--space-2); min-width: 0; }
.imgpick__btns { display: flex; flex-wrap: wrap; gap: var(--space-2); }
.imgpick__url { font-size: var(--text-sm); }

/* Dashboard do Secretário — cartões por departamento */
.dep-card { padding: var(--space-4); margin-bottom: var(--space-3); background: var(--surface, var(--bg-muted)); border: 1px solid var(--border); border-radius: var(--radius-lg); }
.dep-card__head { display: flex; align-items: center; gap: var(--space-3); }
.dep-card__ic { display: inline-flex; align-items: center; justify-content: center; width: 38px; height: 38px; border-radius: var(--radius-md); background: var(--primary-bg, var(--bg-muted)); color: var(--primary); flex-shrink: 0; }
.dep-card__id { display: flex; flex-direction: column; min-width: 0; flex: 1; }
.dep-card__sigla { font-weight: var(--fw-semibold); color: var(--text); font-size: var(--text-sm); }
.dep-card__nome { font-size: var(--text-xs); color: var(--text-secondary); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.dep-card__total { font-size: var(--text-2xl); font-weight: var(--fw-bold); color: var(--text); line-height: 1; display: flex; flex-direction: column; align-items: flex-end; }
.dep-card__total small { font-size: var(--text-xs); font-weight: var(--fw-regular); color: var(--text-secondary); }
.dep-card__stats { display: flex; gap: var(--space-2); margin: var(--space-3) 0 var(--space-3); }
.dep-stat { flex: 1; text-align: center; padding: var(--space-2) 0; background: var(--bg-muted); border-radius: var(--radius-md); }
.dep-stat__num { display: block; font-weight: var(--fw-semibold); color: var(--text); }
.dep-stat__lbl { display: block; font-size: var(--text-xs); color: var(--text-secondary); }
.dep-card__bar { height: 6px; border-radius: 999px; background: var(--bg-muted); overflow: hidden; }
.dep-card__bar-fill { display: block; height: 100%; border-radius: 999px; background: var(--success, #34d399); transition: width .4s ease; }

/* Dashboard — gráfico de torres (SVG) + programas ativos */
.dash-chart-wrap { background: var(--bg-muted); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: var(--space-3) var(--space-2) var(--space-2); }
.dash-chart { width: 100%; height: auto; display: block; }
.dash-chart .dash-bar { fill: var(--text-secondary); }
.dash-chart .dash-bar--now { fill: var(--success, #34d399); }
.dash-chart .dash-bar-val { fill: var(--text); font-size: 9px; font-weight: 600; text-anchor: middle; }
.dash-chart .dash-bar-lbl { fill: var(--text-secondary); font-size: 9px; text-anchor: middle; }

/* Donut / rosca — distribuição por departamento */
.dash-donut-wrap { background: var(--bg-muted); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: var(--space-4) var(--space-3); }
.dash-donut { display: flex; align-items: center; gap: var(--space-4); flex-wrap: wrap; justify-content: center; }
.dash-donut__chart { flex-shrink: 0; }
.dash-donut__svg { width: 148px; height: 148px; display: block; }
.dash-donut__total { fill: var(--text); font-size: 22px; font-weight: var(--fw-bold); text-anchor: middle; }
.dash-donut__cap { fill: var(--text-secondary); font-size: 10px; text-transform: uppercase; letter-spacing: .1em; text-anchor: middle; }
.dash-leg { list-style: none; margin: 0; padding: 0; flex: 1 1 200px; min-width: 0; display: flex; flex-direction: column; gap: var(--space-2); }
.dash-leg__item { display: flex; align-items: center; gap: var(--space-2); font-size: var(--text-sm); }
.dash-leg__dot { width: 12px; height: 12px; border-radius: 4px; flex-shrink: 0; }
.dash-leg__nome { color: var(--text-secondary); min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.dash-leg__val { margin-left: auto; color: var(--text); font-weight: var(--fw-bold); white-space: nowrap; }
.dash-leg__val small { color: var(--text-secondary); font-weight: var(--fw-regular); margin-left: 6px; }

.dash-prog { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--space-2); }
.prog { padding: var(--space-3); background: var(--bg-muted); border: 1px solid var(--border); border-radius: var(--radius-md); }
.prog__top { display: flex; align-items: center; gap: var(--space-2); margin-bottom: var(--space-1); }
.prog__ic { color: var(--primary); display: inline-flex; }
.prog__nome { font-size: var(--text-xs); color: var(--text-secondary); }
.prog__val { font-size: var(--text-xl); font-weight: var(--fw-bold); color: var(--text); line-height: 1.1; }
.prog__delta { font-size: var(--text-xs); font-weight: 600; margin-top: 2px; }
.prog__delta--up { color: var(--success, #34d399); }
.prog__delta--down { color: var(--danger, #f87171); }

/* Dashboard — hero, dropdown, KPI cards */
.painel--dash { padding-top: 0; }

/* Cabeçalho-herói PADRÃO ÚNICO (todas as telas internas via staffHeader) —
   mesma faixa alta + gradiente + pílula "Voltar" do Painel/Dashboard (.dash-hero). */
.staff-hero { position: relative; display: flex; flex-direction: column; margin: 0 0 var(--space-4); padding: calc(var(--space-6) + var(--safe-top)) var(--space-5) var(--space-5); background: linear-gradient(135deg, #0b1530 0%, #16213f 60%, #1a2640 100%); border-bottom: 1px solid var(--border); }
.staff-hero__back { display: inline-flex; align-items: center; gap: 6px; align-self: flex-start; margin-bottom: var(--space-3); padding: 7px 14px 7px 10px; border-radius: 999px; border: 1px solid var(--border); background: rgba(255,255,255,.06); color: var(--text); font: inherit; font-size: var(--text-sm); font-weight: var(--fw-semibold, 600); cursor: pointer; -webkit-appearance: none; appearance: none; }
.staff-hero__back .icon { width: 18px; height: 18px; }
.staff-hero__back:hover { background: rgba(255,255,255,.12); }

/* Botão Voltar dos heróis do Painel/Dashboard (pílula no topo) */
.dash-hero__back { display: inline-flex; align-items: center; gap: 6px; align-self: flex-start; margin-bottom: var(--space-3); padding: 7px 14px 7px 10px; border-radius: 999px; border: 1px solid var(--border); background: rgba(255,255,255,.06); color: var(--text); font: inherit; font-size: var(--text-sm); font-weight: var(--fw-semibold, 600); cursor: pointer; -webkit-appearance: none; appearance: none; position: relative; z-index: 1; }
.dash-hero__back:hover { background: rgba(255,255,255,.12); }
.dash-hero__back .icon { width: 18px; height: 18px; }

/* Esconde TODOS os botões Voltar quando não há tela anterior (evita "no-op"). */
body[data-canback="0"] [data-back] { display: none; }
.staff-hero__txt { min-width: 0; }
.staff-hero__eyebrow { font-size: var(--text-xs); text-transform: uppercase; letter-spacing: .12em; color: var(--text-secondary); }
.staff-hero__title { font-size: var(--text-2xl); font-weight: var(--fw-bold); color: var(--text); line-height: 1.1; }
.staff-hero__bg { position: absolute; inset: 0; overflow: hidden; pointer-events: none; }
.staff-hero__mascote { position: absolute; right: 10px; bottom: 0; height: 92px; width: auto; opacity: 1; pointer-events: none; filter: drop-shadow(0 2px 6px rgba(0,0,0,.35)); }
.staff-hero__back, .staff-hero__txt { position: relative; z-index: 1; }

/* Buscar cidadão (recepção) */
.search-row { display: flex; gap: var(--space-2); }
.search-row .field__control { flex: 1; }
.person { display: flex; align-items: center; gap: var(--space-3); padding: var(--space-4); background: var(--bg-muted); border: 1px solid var(--border); border-radius: var(--radius-lg); margin-bottom: var(--space-3); }
.person__avatar { display: inline-flex; align-items: center; justify-content: center; width: 48px; height: 48px; border-radius: 50%; background: var(--primary-subtle, rgba(255,255,255,.08)); color: var(--primary); font-weight: var(--fw-bold); flex-shrink: 0; }
.person__body { display: flex; flex-direction: column; gap: 1px; flex: 1; min-width: 0; }
.person__nome { font-weight: var(--fw-semibold); color: var(--text); }
.person__meta { font-size: var(--text-sm); color: var(--text-secondary); }
.person__actions { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-2); }
.dash-hero { position: relative; margin: 0 0 var(--space-4); padding: calc(var(--space-6) + var(--safe-top)) var(--space-5) var(--space-5); background: linear-gradient(135deg, #0b1530 0%, #16213f 60%, #1a2640 100%); border-bottom: 1px solid var(--border); }
.dash-hero__bg { position: absolute; inset: 0; overflow: hidden; pointer-events: none; }
.dash-hero__mascote { position: absolute; right: 12px; bottom: 0; height: 124px; width: auto; opacity: 1; pointer-events: none; filter: drop-shadow(0 2px 8px rgba(0,0,0,.35)); }
.dash-hero__row { position: relative; z-index: 1; display: flex; align-items: flex-start; justify-content: space-between; gap: var(--space-3); }
.dash-hero__id { min-width: 0; }
.dash-hero__hello { font-size: var(--text-2xl); font-weight: var(--fw-bold); color: var(--text); line-height: 1.1; }
.dash-hero__role { display: inline-flex; align-items: center; gap: 6px; font-size: var(--text-sm); color: var(--text-secondary); margin-top: 2px; }
.dash-hero__role .icon { width: 15px; height: 15px; }

/* Ação principal em destaque (Painel do CadÚnico) — o botão grande do que a pessoa mais faz */
.dash-primary { display: flex; align-items: center; gap: var(--space-3); margin: var(--space-4) var(--space-5) 0; padding: var(--space-4) var(--space-5); background: linear-gradient(135deg, var(--accent-blue-600, #2563eb), #1d4ed8); border-radius: var(--radius-2xl, 18px); color: #fff; box-shadow: var(--shadow-md, 0 6px 20px rgba(37,99,235,.35)); text-decoration: none; }
.dash-primary:active { transform: translateY(1px); }
.dash-primary__ic { flex-shrink: 0; display: grid; place-items: center; width: 48px; height: 48px; border-radius: 50%; background: rgba(255,255,255,.18); }
.dash-primary__ic .icon { width: 26px; height: 26px; }
.dash-primary__txt { flex: 1 1 auto; min-width: 0; display: flex; flex-direction: column; }
.dash-primary__label { font-size: var(--text-lg); font-weight: var(--fw-bold); }
.dash-primary__hint { font-size: var(--text-sm); color: rgba(255,255,255,.8); }
.dash-primary__arrow { flex-shrink: 0; opacity: .85; }

/* Lista de usuários (equipe do CadÚnico) no modal */
.userlist { display: flex; flex-direction: column; gap: var(--space-2); max-height: 60vh; overflow-y: auto; }
.userlist__row { display: flex; align-items: center; gap: var(--space-3); padding: var(--space-2) var(--space-3); background: var(--bg-muted, rgba(255,255,255,.03)); border: 1px solid var(--border); border-radius: var(--radius-lg); }
.userlist__id { min-width: 0; display: flex; flex-direction: column; }
.userlist__nome { font-weight: var(--fw-semibold); color: var(--text); }
.userlist__sub { font-size: var(--text-xs); color: var(--text-secondary); }
.dash-hero__logout { display: inline-flex; align-items: center; justify-content: center; width: 40px; height: 40px; border-radius: 50%; border: 1px solid var(--border); background: rgba(255,255,255,.06); color: var(--text); cursor: pointer; flex-shrink: 0; }
.dash-hero__logout:hover { background: rgba(255,255,255,.12); }
.dash-hero__big { position: relative; margin-top: var(--space-5); }
.dash-hero__bignum { display: block; font-size: clamp(44px, 15vw, 64px); font-weight: var(--fw-bold); line-height: 1; letter-spacing: var(--tracking-tighter, -.02em); color: var(--text); }
.dash-hero__biglbl { display: block; font-size: var(--text-sm); color: var(--text-secondary); margin-top: var(--space-1); }
.dash-hero__bigsub { display: block; font-size: var(--text-xs); color: var(--text-secondary); margin-top: 2px; }

.dropdown { position: relative; }
.dropdown__btn { display: inline-flex; align-items: center; gap: var(--space-1); padding: var(--space-2) var(--space-3); border-radius: 999px; border: 1px solid var(--border); background: rgba(255,255,255,.06); color: var(--text); font-size: var(--text-sm); font-weight: var(--fw-medium); cursor: pointer; white-space: nowrap; }
.dropdown__btn:hover { background: rgba(255,255,255,.12); }
.dropdown__caret { opacity: .7; }
.dropdown__menu { position: absolute; right: 0; top: calc(100% + 6px); min-width: 168px; margin: 0; padding: var(--space-1); list-style: none; background: var(--bg-muted); border: 1px solid var(--border); border-radius: var(--radius-md); box-shadow: var(--shadow-lg, 0 12px 32px rgba(0,0,0,.45)); z-index: 20; }
.dropdown__menu[hidden] { display: none; }
.dropdown__menu button { display: block; width: 100%; text-align: left; padding: var(--space-2) var(--space-3); border: none; background: none; color: var(--text); font-size: var(--text-sm); border-radius: var(--radius-sm, 6px); cursor: pointer; }
.dropdown__menu button:hover { background: rgba(255,255,255,.08); }

.kpi-row { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--space-2); padding: 0 var(--space-5); margin-bottom: var(--space-4); }
.kpi { padding: var(--space-3); background: var(--bg-muted); border: 1px solid var(--border); border-radius: var(--radius-lg); }
.kpi__head { display: flex; align-items: center; gap: var(--space-2); margin-bottom: var(--space-1); }
.kpi__ic { display: inline-flex; align-items: center; justify-content: center; width: 28px; height: 28px; border-radius: var(--radius-sm, 6px); background: rgba(255,255,255,.06); color: var(--primary); flex-shrink: 0; }
.kpi__label { font-size: var(--text-xs); color: var(--text-secondary); line-height: 1.2; }
.kpi__val { font-size: var(--text-2xl); font-weight: var(--fw-bold); color: var(--text); line-height: 1.1; }
.kpi__foot { display: flex; align-items: baseline; gap: var(--space-2); margin-top: 2px; flex-wrap: wrap; }
.kpi__delta { font-size: var(--text-xs); font-weight: 700; }
.kpi__delta--up { color: var(--success, #34d399); }
.kpi__delta--down { color: var(--danger, #f87171); }
.kpi__proj { font-size: var(--text-xs); color: var(--text-secondary); }

/* ── Dashboard no DESKTOP: espalha pela página (estilo site). Mobile-first intacto. ── */
.dash-cta { padding: 0 var(--space-5); margin: var(--space-2) 0 var(--space-6); }
@media (min-width: 768px) {
  .painel.painel--dash { max-width: 1200px; }
  .painel--dash .kpi-row { grid-template-columns: repeat(4, 1fr); gap: var(--space-3); }
  .painel--dash .kpi { padding: var(--space-4); }
  .painel--dash .kpi__val { font-size: var(--text-3xl, 30px); }
  .dash-2col { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-4); padding: 0 var(--space-5); align-items: start; }
  .dash-2col .painel__section { padding-left: 0; padding-right: 0; }
  .painel--dash #dash-deps { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--space-3); }
  .painel--dash #dash-deps .dep-card { margin-bottom: 0; }
  .painel--dash .dash-prog { grid-template-columns: repeat(3, 1fr); gap: var(--space-3); }
  .dash-hero__mascote { height: 168px; opacity: 1; }
  .dash-cta { max-width: 420px; }
}
@media (min-width: 1080px) {
  .painel--dash #dash-deps { grid-template-columns: repeat(4, 1fr); }
}

.dash-live { display: inline-flex; align-items: center; gap: 5px; font-size: var(--text-xs); color: var(--text-secondary); }
.dash-live__dot { width: 7px; height: 7px; border-radius: 50%; background: var(--success, #34d399); box-shadow: 0 0 0 0 rgba(52,211,153,.6); animation: dashPulse 1.8s infinite; }
@keyframes dashPulse { 0% { box-shadow: 0 0 0 0 rgba(52,211,153,.5); } 70% { box-shadow: 0 0 0 6px rgba(52,211,153,0); } 100% { box-shadow: 0 0 0 0 rgba(52,211,153,0); } }

/* Metas da gestão + orçamento (visão estratégica do Secretário) */
.dash-metas { list-style: none; margin: 0; padding: var(--space-4) var(--space-4); display: grid; gap: var(--space-4); background: var(--bg-muted); border: 1px solid var(--border); border-radius: var(--radius-lg); }
.dash-meta__top { display: flex; justify-content: space-between; align-items: baseline; gap: var(--space-2); margin-bottom: 6px; }
.dash-meta__nome { font-size: var(--text-sm); color: var(--text); }
.dash-meta__val { font-size: var(--text-sm); font-weight: var(--fw-semibold); color: var(--text); font-variant-numeric: tabular-nums; }
.dash-meta__val small { color: var(--text-secondary); font-weight: var(--fw-regular, 400); }
.dash-meta__track { height: 9px; border-radius: 999px; background: var(--border); overflow: hidden; }
.dash-meta__fill { display: block; height: 100%; border-radius: 999px; background: linear-gradient(90deg, var(--accent-blue-600, #2563eb), #60a5fa); transform-origin: left; animation: dashBairroIn .7s cubic-bezier(.2,.8,.2,1) backwards; animation-delay: calc(var(--i, 0) * .07s); }
.dash-meta__fill--money { background: linear-gradient(90deg, var(--success, #34d399), #6ee7b7); }
.dash-meta__pct { display: inline-block; margin-top: 5px; font-size: var(--text-xs); color: var(--text-secondary); }
.dash-orc { padding: var(--space-4); background: var(--bg-muted); border: 1px solid var(--border); border-radius: var(--radius-lg); }
.dash-orc__row { display: flex; justify-content: space-between; align-items: baseline; gap: var(--space-2); margin-bottom: 8px; }
.dash-orc__val { font-weight: var(--fw-semibold); color: var(--text); }
.dash-orc__val small { color: var(--text-secondary); font-weight: var(--fw-regular, 400); }
.dash-orc__foot { display: flex; justify-content: space-between; align-items: center; margin-top: 6px; }
.dash-orc__cmp { font-size: var(--text-xs); font-weight: var(--fw-semibold); }
.dash-orc__cmp--up { color: var(--success, #34d399); }
.dash-orc__cmp--down { color: var(--danger, #f87171); }

/* Permissões — matriz cargo × permissão (controle do Secretário) */
.perm { background: var(--bg-muted); border: 1px solid var(--border); border-radius: var(--radius-lg); overflow: hidden; }
.perm__head, .perm__row { display: grid; grid-template-columns: 1fr 64px 64px; align-items: center; gap: var(--space-2); padding: var(--space-3) var(--space-4); }
.perm__head { background: rgba(255,255,255,.03); border-bottom: 1px solid var(--border); }
.perm__col { text-align: center; font-size: var(--text-xs); font-weight: var(--fw-semibold); color: var(--text-secondary); text-transform: uppercase; letter-spacing: .04em; }
.perm__grupo { border-bottom: 1px solid var(--border); }
.perm__grupo:last-child { border-bottom: 0; }
.perm__gtit { padding: var(--space-3) var(--space-4) 0; font-size: var(--text-xs); text-transform: uppercase; letter-spacing: .08em; color: var(--text-secondary); }
.perm__row + .perm__row { border-top: 1px solid var(--border-subtle); }
.perm__lbl { font-size: var(--text-sm); color: var(--text); }
.perm__sw { justify-self: center; gap: 0; }
.perm__hint { display: flex; align-items: flex-start; gap: var(--space-2); margin-top: var(--space-3); font-size: var(--text-xs); color: var(--text-secondary); }
.perm__hint .icon { color: var(--info); flex-shrink: 0; }

/* Ações de gestão da fila (priorizar/cancelar) */
.fila-acts { display: inline-flex; gap: 6px; }
.fila-act { display: inline-flex; align-items: center; justify-content: center; width: 34px; height: 34px; border-radius: 50%; border: 1px solid var(--border); background: rgba(255,255,255,.06); color: var(--text); cursor: pointer; -webkit-appearance: none; appearance: none; }
.fila-act:hover { background: rgba(255,255,255,.12); border-color: var(--accent-blue-600, #2563eb); }
.fila-act--danger:hover { border-color: var(--danger, #f87171); color: var(--danger, #f87171); }

/* Andamento agora (gestão vê o movimento ao vivo — sem operar) */
.andamento { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-3); }
.andamento__card { display: flex; flex-direction: column; gap: var(--space-2); padding: var(--space-4); background: var(--bg-muted); border: 1px solid var(--border); border-radius: var(--radius-lg); }
.andamento__num { font-size: var(--text-3xl, 30px); font-weight: var(--fw-bold); line-height: 1; color: var(--text); font-variant-numeric: tabular-nums; }
.andamento__lbl { font-size: var(--text-sm); color: var(--text-secondary); }

/* Atendimentos por bairro (Abaetetuba) — barras horizontais */
.dash-pin { display: inline-flex; align-items: center; gap: 4px; font-size: var(--text-xs); color: var(--text-secondary); }
.dash-pin .icon { width: 14px; height: 14px; }
.dash-bairros { list-style: none; margin: 0; padding: var(--space-4) var(--space-3); display: grid; gap: var(--space-3); background: var(--bg-muted); border: 1px solid var(--border); border-radius: var(--radius-lg); }
.dash-bairro { display: grid; grid-template-columns: 96px 1fr auto; align-items: center; gap: var(--space-3); }
.dash-bairro__nome { font-size: var(--text-sm); color: var(--text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.dash-bairro__track { height: 8px; border-radius: 999px; background: var(--border); overflow: hidden; }
.dash-bairro__fill { display: block; height: 100%; border-radius: 999px; background: linear-gradient(90deg, var(--accent-blue-600, #2563eb), #60a5fa); transform-origin: left center; animation: dashBairroIn .7s cubic-bezier(.2,.8,.2,1) backwards; animation-delay: calc(var(--i) * .06s); }
.dash-bairro__val { font-size: var(--text-sm); font-weight: var(--fw-semibold); color: var(--text); font-variant-numeric: tabular-nums; min-width: 34px; text-align: right; }
@keyframes dashBairroIn { from { transform: scaleX(0); } to { transform: scaleX(1); } }
@media (prefers-reduced-motion: reduce) { .dash-bairro__fill { animation: none; } }

/* Equipe — gestão de cargos do Secretário */
.team-row { display: flex; align-items: center; gap: var(--space-3); padding: var(--space-3); margin-bottom: var(--space-2); background: var(--bg-muted); border: 1px solid var(--border); border-radius: var(--radius-lg); }
.team-row__av { flex-shrink: 0; width: 40px; height: 40px; border-radius: 50%; display: grid; place-items: center; font-weight: var(--fw-bold); color: var(--text); background: linear-gradient(135deg, var(--accent-blue-600, #2563eb), #60a5fa); }
.team-row__id { min-width: 0; flex: 1; display: flex; flex-direction: column; }
.team-row__nome { font-size: var(--text-sm); font-weight: var(--fw-semibold); color: var(--text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.team-row__nome small { color: var(--text-secondary); font-weight: var(--fw-regular, 400); }
.team-row__email { font-size: var(--text-xs); color: var(--text-secondary); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.team__select { flex-shrink: 0; font: inherit; font-size: var(--text-sm); color: var(--text); background: var(--bg); border: 1px solid var(--border); border-radius: var(--radius-md); padding: 8px 10px; cursor: pointer; -webkit-appearance: none; appearance: none; }
.team__select:hover { border-color: var(--accent-blue-600, #2563eb); }
.team__pill { flex-shrink: 0; display: inline-flex; align-items: center; gap: 5px; font-size: var(--text-xs); color: var(--text-secondary); padding: 6px 10px; border: 1px solid var(--border); border-radius: 999px; }
.team__pill .icon { width: 14px; height: 14px; }
.team-row__acesso { flex-shrink: 0; display: inline-flex; align-items: center; justify-content: center; width: 38px; height: 38px; border-radius: 50%; border: 1px solid var(--border); background: var(--bg-muted, rgba(255,255,255,.03)); color: var(--text-secondary); cursor: pointer; }
.team-row__acesso:hover { color: var(--accent-blue-600, #60a5fa); border-color: var(--accent-blue-600, #2563eb); }
/* Adicionar servidor / formulários de cadastro */
.team-add { display: flex; flex-direction: column; gap: var(--space-3); padding: var(--space-4); background: var(--bg-muted); border: 1px solid var(--border); border-radius: var(--radius-lg); }
.team-add__grid, .form-grid { display: grid; grid-template-columns: 1fr; gap: var(--space-3); }
@media (min-width: 560px) { .team-add__grid, .form-grid { grid-template-columns: 1fr 1fr; } }
.team-add .field__error { color: var(--danger); font-size: var(--text-xs); }
/* Cadastro concluído */
.cad-done { display: flex; align-items: center; gap: var(--space-3); padding: var(--space-4); margin-bottom: var(--space-3); background: var(--success-bg); border: 1px solid var(--success); border-radius: var(--radius-lg); }
.cad-done__ic { flex-shrink: 0; width: 40px; height: 40px; border-radius: 50%; display: grid; place-items: center; background: var(--success); color: #06281c; }
.cad-done__txt { display: flex; flex-direction: column; }
.cad-done__txt strong { color: var(--text); }
.cad-done__txt span { color: var(--text-secondary); font-size: var(--text-sm); }
.choice-actions { display: flex; flex-direction: column; gap: var(--space-2); }

/* Cartão de credenciais (Equipe → após cadastrar servidor): login + senha temporária */
.cred { background: var(--bg-muted, rgba(255,255,255,.03)); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: var(--space-4); }
.cred__row { display: flex; align-items: center; justify-content: space-between; gap: var(--space-3); padding: var(--space-2) 0; border-bottom: 1px solid var(--border-subtle, var(--border)); }
.cred__row:first-child { padding-top: 0; }
.cred__lbl { font-size: var(--text-xs); text-transform: uppercase; letter-spacing: .08em; color: var(--text-secondary); }
.cred__val { font-weight: var(--fw-bold); color: var(--text); }
.cred .btn { margin-top: var(--space-3); }

/* Gráfico de área (linha + grade + pontos) */
.dash-line { stroke: var(--success, #34d399); stroke-width: 2.2; stroke-linejoin: round; stroke-linecap: round; }
.dash-grid { stroke: var(--border); stroke-width: 1; stroke-dasharray: 2 4; }

/* Animações de entrada do dashboard (só nos blocos renderizados 1x — deps atualizam ao vivo) */
@keyframes dashDraw { to { stroke-dashoffset: 0; } }
@keyframes dashBarGrow { from { transform: scaleY(0); } to { transform: scaleY(1); } }
@keyframes dashUp { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: none; } }
.dash-line { stroke-dasharray: 1400; stroke-dashoffset: 1400; animation: dashDraw 1.3s ease-out forwards; }
.dash-chart .dash-dot { animation: dashUp .5s ease-out .9s backwards; }
.dash-chart .dash-bar { transform-box: fill-box; transform-origin: center bottom; animation: dashBarGrow .7s cubic-bezier(.2,.8,.2,1) backwards; }
.painel--dash .kpi { animation: dashUp .5s ease-out backwards; }
.painel--dash .kpi:nth-child(2) { animation-delay: .07s; }
.painel--dash .kpi:nth-child(3) { animation-delay: .14s; }
.painel--dash .kpi:nth-child(4) { animation-delay: .21s; }
.painel--dash .prog { animation: dashUp .5s ease-out backwards; }
@keyframes dashFade { from { opacity: 0; } to { opacity: 1; } }
.dash-donut__seg { opacity: 0; animation: dashFade .5s ease-out forwards; animation-delay: calc(.15s + var(--i, 0) * .18s); }
@media (prefers-reduced-motion: reduce) {
  .dash-line, .dash-chart .dash-dot, .dash-chart .dash-bar, .painel--dash .kpi, .painel--dash .prog { animation: none; stroke-dashoffset: 0; }
  .dash-donut__seg { animation: none; opacity: 1; }
}
.dash-dot { fill: var(--bg-muted); stroke: var(--success, #34d399); stroke-width: 2; }
.dash-dot--now { fill: var(--success, #34d399); stroke: var(--text); }

/* Serviços / Módulos — catálogo com isca de upsell */
.modcat { display: flex; flex-direction: column; gap: var(--space-3); }
.modcard { display: flex; align-items: center; gap: var(--space-3); width: 100%; text-align: left; font: inherit; color: var(--text); padding: var(--space-4); background: var(--bg-muted); border: 1px solid var(--border); border-radius: var(--radius-lg); cursor: pointer; transition: border-color .15s ease, opacity .15s ease, transform .1s ease; }
.modcard:active { transform: scale(.99); }
.modcard--ativo:hover { border-color: var(--success, #34d399); }
.modcard--locked { opacity: .6; }
.modcard--locked:hover { opacity: .82; border-color: var(--text-secondary); }
.modcard__ic { display: inline-flex; align-items: center; justify-content: center; width: 46px; height: 46px; border-radius: var(--radius-md); background: rgba(255,255,255,.06); color: var(--text-secondary); flex-shrink: 0; }
.modcard--ativo .modcard__ic { background: var(--success-bg, rgba(52,211,153,.12)); color: var(--success, #34d399); }
.modcard__body { display: flex; flex-direction: column; gap: 2px; flex: 1; min-width: 0; }
.modcard__title { font-weight: var(--fw-semibold); color: var(--text); }
.modcard__desc { font-size: var(--text-sm); color: var(--text-secondary); }
.modcard__badge { display: inline-flex; align-items: center; gap: 4px; font-size: var(--text-xs); font-weight: 700; padding: 4px 10px; border-radius: 999px; white-space: nowrap; flex-shrink: 0; }
.modcard__badge--on { background: var(--success-bg, rgba(52,211,153,.12)); color: var(--success, #34d399); }
.modcard__badge--soon { background: rgba(255,255,255,.06); color: var(--text-secondary); }

/* Monitor / Painel de chamada (TV da sala de espera) */
.monitor { position: fixed; inset: 0; z-index: 60; color: var(--text); background: radial-gradient(circle at 50% 28%, #11224d 0%, #081126 68%); }
.monitor__start[hidden], .monitor__stage[hidden] { display: none; }   /* hidden vence o display:flex */
.monitor__start { position: absolute; inset: 0; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: var(--space-5); text-align: center; padding: var(--space-6); }
.monitor__startlogo { height: clamp(96px, 14vw, 180px); width: auto; }
.monitor__starthint { color: var(--text-secondary); font-size: var(--text-sm); }
.monitor__stage { display: flex; flex-direction: column; height: 100%; padding: clamp(16px, 4vw, 48px); }
.monitor__top { display: flex; align-items: center; justify-content: space-between; }
.monitor__logo { height: clamp(60px, 10vw, 132px); width: auto; }
.monitor__clock { font-size: clamp(32px, 5vw, 64px); font-weight: var(--fw-bold); color: var(--text); font-variant-numeric: tabular-nums; }
.monitor__main { flex: 1; display: flex; align-items: center; justify-content: center; }
.monitor__senha { text-align: center; }
.monitor__senhalbl { font-size: clamp(16px, 3vw, 28px); color: var(--text-secondary); letter-spacing: .25em; text-transform: uppercase; }
.monitor__senhanum { font-size: clamp(96px, 26vw, 340px); font-weight: var(--fw-bold); line-height: .92; letter-spacing: -.02em; }
.monitor__guiche { font-size: clamp(28px, 6vw, 76px); font-weight: var(--fw-semibold); color: var(--success, #34d399); margin-top: var(--space-3); }
.monitor__serv { font-size: clamp(16px, 3vw, 30px); color: var(--text-secondary); margin-top: var(--space-2); }
.monitor__wait { font-size: clamp(28px, 5vw, 56px); color: var(--text-secondary); }
.monitor__last { display: flex; align-items: center; gap: var(--space-3); flex-wrap: wrap; justify-content: center; min-height: 44px; }
.monitor__lastlbl { color: var(--text-secondary); text-transform: uppercase; letter-spacing: .15em; font-size: var(--text-sm); }
.monitor__chip { display: inline-flex; align-items: baseline; gap: 4px; padding: 6px 16px; border-radius: 999px; background: var(--bg-muted); border: 1px solid var(--border); font-size: clamp(18px, 3vw, 30px); font-weight: var(--fw-semibold); }
.monitor__chip small { color: var(--text-secondary); font-size: .6em; }
.monitor__senha.is-new { animation: monFlash .9s ease; }
@keyframes monFlash { 0% { transform: scale(.9); opacity: .35; } 55% { transform: scale(1.05); } 100% { transform: scale(1); opacity: 1; } }

/* ── Responsivo ── */
@media (min-width: 560px) {
  .lp-hero__sub { font-size: var(--text-lg); }
  .lp-hero__cta { flex-direction: row; justify-content: center; max-width: none; }
  .lp-stats { grid-template-columns: repeat(4, 1fr); }
  .lp-card { width: 320px; }
}
@media (min-width: 880px) {
  .lp-nav__menu { display: flex; }
  .lp-nav__logo2 { display: block; }
  .lp-brand__logo { height: 56px; }
  .lp-hero__logo { width: min(56vw, 520px); }
  .lp-foot__crest { width: 156px; height: 156px; }
  .lp-foot__brasao { height: 138px; }
  .lp-burger { display: none; }
  .lp-map__grid { grid-template-columns: 1.4fr 1fr; gap: var(--space-8); }
  .lp-sec { padding: var(--space-20) var(--space-6); }

  /* Cards viram GRADE no desktop (sem carrossel/setas) — distribui melhor a largura */
  .lp-cards__nav { display: none; }
  .lp-cards__viewport { overflow: visible; margin: 0; padding: 0; cursor: default; }
  .lp-cards__track { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-5); }
  .lp-card { width: auto; }
}

@media (min-width: 1180px) {
  .lp-cards__track { grid-template-columns: repeat(4, 1fr); }
}

/* ════════════════ BOTÃO CTA (amarelo chamativo) ════════════════ */
.btn--cta { color: #1a1205; background: #fbbf24; border-color: #fbbf24; font-weight: var(--fw-semibold); box-shadow: 0 8px 24px rgba(251,191,36,0.25); }
.btn--cta:hover { background: #fcd34d; border-color: #fcd34d; }

/* ════════════════ LP SECUNDÁRIA — CAD ÚNICO (/cadunico, /cadastro) ════════════════ */
.cad { max-width: 920px; margin: 0 auto; padding: 0 var(--space-5) var(--space-16); }
.cad__top { display: flex; align-items: center; justify-content: space-between; gap: var(--space-4); padding: calc(var(--space-4) + var(--safe-top)) 0 var(--space-4); }
.cad__brand img { height: 40px; width: auto; object-fit: contain; }
.cad__topnav { display: inline-flex; align-items: center; gap: var(--space-3); flex-wrap: wrap; justify-content: flex-end; }
.cad__hello { display: inline-flex; align-items: center; gap: var(--space-2); font-size: var(--text-sm); font-weight: var(--fw-medium); color: var(--text-secondary); }
.cad__back { display: inline-flex; align-items: center; gap: var(--space-2); font-size: var(--text-sm); font-weight: var(--fw-medium); color: var(--text-secondary); }
.cad__back:hover { color: var(--text); }

.cad__hero { text-align: center; padding: var(--space-12) 0 var(--space-10); }
.cad__badge { display: inline-flex; align-items: center; gap: var(--space-2); margin-bottom: var(--space-5); padding: 6px var(--space-4); font-size: var(--text-xs); font-weight: var(--fw-medium); color: var(--text-secondary); background: rgba(245,245,245,0.04); border: 1px solid var(--border-strong); border-radius: var(--radius-full); }
.cad__title { font-size: clamp(var(--text-3xl), 6vw, 56px); font-weight: var(--fw-bold); letter-spacing: var(--tracking-tighter); line-height: 1.08; }
.cad__sub { max-width: 60ch; margin: var(--space-5) auto 0; font-size: var(--text-lg); color: var(--text-secondary); line-height: 1.6; }
.cad__cta { display: flex; flex-wrap: wrap; justify-content: center; gap: var(--space-3); margin-top: var(--space-8); }

.cad__section { padding: var(--space-12) 0; border-top: 1px solid var(--border-subtle); }
.cad__section--muted { margin: 0 calc(-1 * var(--space-5)); padding: var(--space-12) var(--space-5); background: var(--bg-subtle); border-block: 1px solid var(--border-subtle); }
.cad__sectitle { font-size: clamp(var(--text-2xl), 4vw, var(--text-3xl)); font-weight: var(--fw-bold); letter-spacing: var(--tracking-tight); }
.cad__lead { max-width: 64ch; margin-top: var(--space-3); font-size: var(--text-base); color: var(--text-secondary); line-height: 1.65; }

.cad__benefits { display: grid; grid-template-columns: 1fr; gap: var(--space-4); margin-top: var(--space-8); }
.cad__benefit { display: flex; gap: var(--space-4); align-items: flex-start; padding: var(--space-5); background: var(--bg-muted); border: 1px solid var(--border); border-radius: var(--radius-xl); }
.cad__benefit-ico { display: inline-flex; align-items: center; justify-content: center; width: 48px; height: 48px; flex: none; color: var(--accent-blue-100, #dbeafe); background: var(--info-bg); border: 1px solid var(--info-border); border-radius: var(--radius-lg); }
.cad__benefit-title { font-size: var(--text-base); font-weight: var(--fw-semibold); }
.cad__benefit-text { font-size: var(--text-sm); color: var(--text-muted); margin-top: 2px; }

.cad__panel { display: flex; gap: var(--space-5); align-items: flex-start; padding: var(--space-6); background: var(--bg-muted); border: 1px solid var(--border-strong); border-radius: var(--radius-2xl); }

.cad__docs { display: flex; flex-direction: column; gap: var(--space-3); margin-top: var(--space-6); }
.cad__doc { display: flex; gap: var(--space-3); align-items: flex-start; font-size: var(--text-base); color: var(--text-secondary); line-height: 1.5; }
.cad__doc .icon-sm { flex: none; margin-top: 3px; color: var(--success); }

.cad__final { text-align: center; padding: var(--space-16) var(--space-5); margin-top: var(--space-12); background: radial-gradient(120% 120% at 50% 0%, rgba(59,130,246,0.12), transparent 70%); border: 1px solid var(--border); border-radius: var(--radius-3xl); }
.cad__final-title { font-size: clamp(var(--text-2xl), 5vw, var(--text-4xl)); font-weight: var(--fw-bold); letter-spacing: var(--tracking-tight); }
.cad__final .btn { margin-top: var(--space-6); }

.cad__foot { display: flex; align-items: center; justify-content: center; gap: var(--space-3); margin-top: var(--space-12); font-size: var(--text-sm); color: var(--text-muted); }
.cad__foot-brasao { height: 40px; width: auto; }

.cad__soon { text-align: center; padding: var(--space-16) var(--space-5); display: flex; flex-direction: column; align-items: center; gap: var(--space-4); }

@media (min-width: 680px) {
  .cad__benefits { grid-template-columns: 1fr 1fr; }
}
@media (min-width: 980px) {
  .cad__benefits { grid-template-columns: repeat(3, 1fr); }
}

/* ════════════════ WIZARD (formulário Cad Único) ════════════════ */
.wiz { max-width: 760px; margin: 0 auto; }
.wiz__progress { margin: var(--space-6) 0 var(--space-10); }
.wiz__compact { display: block; margin-bottom: var(--space-3); font-size: var(--text-sm); font-weight: var(--fw-medium); color: var(--text-secondary); }
.wiz__steps { display: none; gap: var(--space-2); justify-content: space-between; }
.wiz__step { display: flex; flex-direction: column; align-items: center; gap: var(--space-2); flex: 1; text-align: center; }
.wiz__dot { display: inline-flex; align-items: center; justify-content: center; width: 32px; height: 32px; font-size: var(--text-sm); font-weight: var(--fw-semibold); color: var(--text-secondary); background: var(--bg-muted); border: 1px solid var(--border); border-radius: var(--radius-full); }
.wiz__step.is-active .wiz__dot { color: var(--primary-text); background: var(--primary); border-color: var(--primary); }
.wiz__step.is-done .wiz__dot { color: #06281c; background: var(--success); border-color: var(--success); }
.wiz__steplbl { display: none; font-size: var(--text-xs); color: var(--text-subtle); }
.wiz__step.is-active .wiz__steplbl { color: var(--text); }
.wiz__bar { height: 4px; margin-top: var(--space-4); background: var(--bg-muted); border-radius: var(--radius-full); overflow: hidden; }
.wiz__bar span { display: block; height: 100%; background: var(--primary); transition: width var(--duration) var(--ease); }
.wiz__steptitle { display: flex; align-items: center; gap: var(--space-2); font-size: var(--text-2xl); font-weight: var(--fw-bold); letter-spacing: var(--tracking-tight); margin-bottom: var(--space-6); }
.wiz__grid { display: grid; grid-template-columns: 1fr; gap: var(--space-4); }
.wiz__col { display: flex; flex-direction: column; gap: var(--space-4); max-width: 440px; }
.wiz__nav { display: flex; align-items: center; justify-content: space-between; gap: var(--space-3); margin-top: var(--space-8); }
.wiz__members { display: flex; flex-direction: column; gap: var(--space-4); margin: var(--space-4) 0; }
.wiz__member { padding: var(--space-4); background: var(--bg-muted); border: 1px solid var(--border); border-radius: var(--radius-lg); }
.wiz__review { display: flex; flex-direction: column; gap: var(--space-2); margin: var(--space-4) 0; padding: var(--space-5); background: var(--bg-muted); border: 1px solid var(--border); border-radius: var(--radius-lg); }
.wiz__review .adm__listtitle { margin-top: var(--space-3); }
.wiz__rev { display: flex; justify-content: space-between; gap: var(--space-4); font-size: var(--text-sm); color: var(--text-secondary); }
.wiz__rev strong { color: var(--text); text-align: right; }
.wiz__done { display: flex; flex-direction: column; align-items: center; gap: var(--space-4); padding: var(--space-16) var(--space-4); text-align: center; }
.wiz__doneico { display: inline-flex; align-items: center; justify-content: center; width: 72px; height: 72px; color: var(--success); background: var(--success-bg); border: 1px solid var(--success-border); border-radius: var(--radius-full); }
.wiz__doneico .icon { width: 36px; height: 36px; }
.wiz__protocolo { max-width: 100%; font-family: var(--font-mono); font-size: clamp(var(--text-lg), 6vw, var(--text-2xl)); font-weight: var(--fw-bold); letter-spacing: 0.12em; overflow-wrap: anywhere; padding: var(--space-3) var(--space-6); background: var(--bg-muted); border: 1px dashed var(--border-strong); border-radius: var(--radius-lg); }

/* ── Documentos (cards com anexar) ── */
.wiz__dicas { display: flex; align-items: flex-start; gap: var(--space-3); margin-bottom: var(--space-4); padding: var(--space-3) var(--space-4); font-size: var(--text-sm); color: var(--text-secondary); line-height: 1.5; background: var(--info-bg); border: 1px solid var(--info-border); border-radius: var(--radius-lg); }
.wiz__dicas .icon { color: var(--accent, var(--info)); flex: none; }
.wiz__dicas strong { color: var(--text); }
.wiz__doclist { display: flex; flex-direction: column; gap: var(--space-3); }
.wiz__doccard { display: flex; flex-wrap: wrap; align-items: center; gap: var(--space-3); padding: var(--space-3) var(--space-4); background: var(--bg-muted); border: 1px solid var(--border); border-radius: var(--radius-lg); }
.wiz__doccard.is-anexado { border-color: var(--success-border); background: var(--success-bg); }
.wiz__docico { display: inline-flex; align-items: center; justify-content: center; width: 40px; height: 40px; flex: none; color: var(--text-secondary); background: var(--bg-subtle); border: 1px solid var(--border); border-radius: var(--radius-md); }
.wiz__doccard.is-anexado .wiz__docico { color: var(--success); border-color: var(--success-border); }
.wiz__docinfo { display: flex; flex-direction: column; gap: 2px; flex: 1 1 140px; min-width: 0; }
.wiz__docnome { font-size: var(--text-sm); font-weight: var(--fw-medium); }
.wiz__docreq { display: inline-block; margin-left: var(--space-2); padding: 1px 6px; font-size: 10px; font-weight: var(--fw-medium); text-transform: uppercase; letter-spacing: var(--tracking-wide); color: var(--warning); background: var(--warning-bg); border: 1px solid var(--warning-border); border-radius: var(--radius-full); }
.wiz__docstatus { display: inline-flex; align-items: center; gap: 4px; font-size: var(--text-xs); color: var(--text-muted); }
.wiz__doccard.is-anexado .wiz__docstatus { color: var(--success); }
.wiz__docacts { display: flex; flex-wrap: wrap; align-items: center; gap: var(--space-2); flex: none; }
.wiz__docchk { display: inline-flex; align-items: center; gap: 4px; font-size: var(--text-xs); color: var(--text-secondary); cursor: pointer; white-space: nowrap; }
.wiz__prog { display: inline-block; vertical-align: middle; width: 90px; height: 6px; background: var(--bg-subtle); border-radius: var(--radius-full); overflow: hidden; }
.wiz__prog > span { display: block; height: 100%; background: var(--success); transition: width 120ms linear; }
.wiz__progpct { margin-left: var(--space-2); font-style: normal; font-size: var(--text-xs); color: var(--text-secondary); }

/* ── Dropdown com botão "+" (adicionar opção) ── */
.field__withadd { display: flex; gap: var(--space-2); align-items: stretch; }
.field__withadd .field__control { flex: 1; }
.field__add { display: inline-flex; align-items: center; justify-content: center; width: 48px; flex: none; color: var(--text); background: var(--bg-muted); border: 1px solid var(--border-strong); border-radius: var(--radius-lg); cursor: pointer; transition: background var(--duration-fast) var(--ease); }
.field__add:hover { background: var(--bg-subtle); }
@media (min-width: 620px) {
  .wiz__compact { display: none; }
  .wiz__steps { display: flex; }
  .wiz__steplbl { display: block; }
  .wiz__grid { grid-template-columns: 1fr 1fr; }
}

/* ════════════════ MODAL (confirmação de ações destrutivas) ════════════════ */
.modal { position: fixed; inset: 0; z-index: var(--z-modal); display: flex; align-items: center; justify-content: center; padding: var(--space-5); opacity: 0; transition: opacity var(--duration) var(--ease); }
.modal.is-open { opacity: 1; }
.modal__backdrop { position: absolute; inset: 0; background: rgba(0,0,0,0.6); backdrop-filter: blur(2px); }
.modal__box { position: relative; display: flex; flex-direction: column; align-items: center; gap: var(--space-3); width: 100%; max-width: 380px; padding: var(--space-8) var(--space-6); text-align: center; background: var(--bg-muted); border: 1px solid var(--border-strong); border-radius: var(--radius-2xl); box-shadow: var(--shadow-2xl); transform: translateY(8px); transition: transform var(--duration) var(--ease); }
.modal.is-open .modal__box { transform: translateY(0); }
.modal__icon { display: inline-flex; align-items: center; justify-content: center; width: 48px; height: 48px; border-radius: var(--radius-full); }
.modal__icon--danger { color: var(--danger); background: var(--danger-bg); border: 1px solid var(--danger-border); }
.modal__title { font-size: var(--text-lg); font-weight: var(--fw-semibold); }
.modal__msg { font-size: var(--text-sm); color: var(--text-secondary); line-height: 1.55; }
.modal__pin { max-width: 180px; text-align: center; font-size: var(--text-2xl); letter-spacing: 0.4em; }
.modal__err { font-size: var(--text-xs); }
.modal__actions { display: flex; gap: var(--space-3); width: 100%; margin-top: var(--space-2); }
.modal__actions .btn { flex: 1; }
.modal__box--form { align-items: stretch; text-align: left; }
.modal__form { display: flex; flex-direction: column; gap: var(--space-3); width: 100%; }

/* ════════════════ INFO (botão (i) de ajuda nos campos) ════════════════ */
.info { position: relative; display: inline-flex; vertical-align: middle; margin-left: 4px; }
.info-btn { display: inline-flex; align-items: center; color: var(--text-muted); cursor: pointer; }
.info-btn:hover { color: var(--text); }
.info-pop {
  position: absolute; bottom: calc(100% + 8px); left: 50%; transform: translateX(-50%);
  z-index: var(--z-tooltip);
  display: none; width: max-content; max-width: 240px;
  padding: var(--space-3) var(--space-4);
  font-size: var(--text-xs); font-weight: var(--fw-regular); line-height: 1.5; text-align: left; text-transform: none; letter-spacing: normal; color: var(--text);
  background: var(--bg-subtle); border: 1px solid var(--border-strong); border-radius: var(--radius-md); box-shadow: var(--shadow-lg);
}
.info.is-open .info-pop { display: block; }

/* ════════════════ AUTH (login) ════════════════ */
.auth { display: flex; flex-direction: column; min-height: 100dvh; max-width: 460px; margin: 0 auto; padding: calc(var(--space-5) + var(--safe-top)) var(--space-6) calc(var(--space-6) + var(--safe-bottom)); }
.auth__back { display: inline-flex; align-items: center; gap: var(--space-2); font-size: var(--text-sm); font-weight: var(--fw-medium); color: var(--text-secondary); }
.auth__back:hover { color: var(--text); }
.auth__card { display: flex; flex-direction: column; gap: var(--space-3); margin: auto 0; }
.auth__logo { height: 64px; width: auto; max-width: 200px; object-fit: contain; margin: 0 auto var(--space-3); }
.auth__title { text-align: center; font-size: var(--text-2xl); font-weight: var(--fw-bold); letter-spacing: var(--tracking-tight); }
.auth__sub { text-align: center; font-size: var(--text-sm); color: var(--text-muted); margin-top: calc(-1 * var(--space-1)); margin-bottom: var(--space-3); }
.auth__form { display: flex; flex-direction: column; gap: var(--space-4); }
.auth__hint { display: flex; align-items: flex-start; gap: var(--space-2); margin-top: var(--space-5); padding: var(--space-3) var(--space-4); font-size: var(--text-xs); color: var(--text-secondary); background: var(--bg-subtle); border: 1px solid var(--border-subtle); border-radius: var(--radius-lg); }
.auth__hint .icon { color: var(--info); flex-shrink: 0; }
.auth__hintlink { color: var(--accent, var(--info)); font-weight: var(--fw-medium); text-decoration: underline; }

/* Abas Entrar/Criar conta + toggle e-mail/CPF + esqueci senha + Meus dados */
.auth__tabs { display: flex; gap: var(--space-2); margin-bottom: var(--space-4); background: var(--bg-subtle); border: 1px solid var(--border); border-radius: var(--radius-full); padding: 4px; }
.auth__tab { flex: 1; padding: var(--space-2); font-size: var(--text-sm); font-weight: var(--fw-medium); color: var(--text-secondary); border-radius: var(--radius-full); }
.auth__tab.is-active { color: var(--primary-text); background: var(--primary); }
.auth__toggle { display: flex; gap: var(--space-2); }
.auth__toggleopt { flex: 1; padding: var(--space-2); font-size: var(--text-xs); font-weight: var(--fw-medium); color: var(--text-secondary); background: var(--bg-muted); border: 1px solid var(--border); border-radius: var(--radius-md); }
.auth__toggleopt.is-active { color: var(--text); border-color: var(--primary); background: var(--primary-subtle); }
.auth__forgot { align-self: center; font-size: var(--text-sm); color: var(--text-secondary); text-decoration: underline; }
.auth__forgot:hover { color: var(--text); }
.md__lista { display: flex; flex-direction: column; gap: var(--space-3); margin-top: var(--space-4); }
.md__item { display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: var(--space-3); padding: var(--space-4); background: var(--bg-muted); border: 1px solid var(--border); border-radius: var(--radius-lg); }
.md__acts { display: flex; align-items: center; gap: var(--space-3); }
.md__statusmsg { width: 100%; display: flex; align-items: flex-start; gap: var(--space-2); margin: 0; padding-top: var(--space-3); border-top: 1px solid var(--border); font-size: var(--text-sm); color: var(--text-secondary); }
.md__statusmsg i { flex-shrink: 0; margin-top: 2px; color: var(--text-muted); }
.md__statusmsg--warn { color: var(--warning); } .md__statusmsg--warn i { color: var(--warning); }
.md__statusmsg--ok { color: var(--success); } .md__statusmsg--ok i { color: var(--success); }
.md__statusmsg--bad { color: var(--danger); } .md__statusmsg--bad i { color: var(--danger); }
.md__hist { width: 100%; padding-top: var(--space-3); border-top: 1px solid var(--border); }
.md__histtitle { display: inline-flex; align-items: center; gap: var(--space-2); font-size: var(--text-xs); font-weight: var(--fw-semibold); text-transform: uppercase; letter-spacing: var(--tracking-wide); color: var(--text-subtle); }
.md__histlist { list-style: none; margin: var(--space-3) 0 0; padding: 0; display: flex; flex-direction: column; gap: var(--space-2); }
.md__histitem { display: flex; align-items: center; gap: var(--space-2); font-size: var(--text-sm); color: var(--text-secondary); }
.md__histdot { width: 7px; height: 7px; border-radius: var(--radius-full); background: var(--brand-500, var(--text-muted)); flex-shrink: 0; }
.md__histtxt { flex: 1; }
.md__histdata { color: var(--text-muted); font-size: var(--text-xs); white-space: nowrap; }
.md__verify { display: flex; align-items: flex-start; gap: var(--space-2); margin-bottom: var(--space-4); padding: var(--space-3) var(--space-4); font-size: var(--text-sm); color: var(--text); background: var(--warning-bg); border: 1px solid var(--warning-border); border-radius: var(--radius-md); }
.md__verify i { color: var(--warning); flex-shrink: 0; margin-top: 2px; }
.md__btnrow { display: flex; gap: var(--space-3); flex-wrap: wrap; }
.md__toast { position: fixed; left: 50%; bottom: calc(var(--space-6) + var(--safe-bottom, 0px)); transform: translateX(-50%) translateY(20px); background: var(--text); color: var(--bg); padding: var(--space-3) var(--space-5); border-radius: var(--radius-full); font-size: var(--text-sm); font-weight: var(--fw-medium); box-shadow: var(--shadow-lg); opacity: 0; pointer-events: none; transition: opacity .25s, transform .25s; z-index: 200; max-width: 90vw; text-align: center; }
.md__toast.is-show { opacity: 1; transform: translateX(-50%) translateY(0); }
.cam { position: fixed; inset: 0; z-index: 300; background: #000; display: flex; flex-direction: column; }
.cam__stage { position: relative; flex: 1; overflow: hidden; }
.cam__video { width: 100%; height: 100%; object-fit: cover; }
.cam__frame { position: absolute; inset: 8% 6%; border: 2px dashed rgba(255,255,255,0.85); border-radius: 12px; box-shadow: 0 0 0 9999px rgba(0,0,0,0.45); display: flex; align-items: flex-end; justify-content: center; pointer-events: none; }
.cam__hint { margin-bottom: 16px; padding: 6px 14px; background: rgba(0,0,0,0.6); color: #fff; font-size: 13px; border-radius: 999px; }
.cam__bar { display: flex; align-items: center; justify-content: space-between; gap: 16px; padding: 18px 24px calc(18px + var(--safe-bottom, 0px)); background: #000; }
.cam__cancel { background: transparent; border: 0; color: #fff; font-size: 15px; font-weight: 600; cursor: pointer; flex: 1; text-align: left; }
.cam__spacer { flex: 1; }
.cam__shutter { width: 68px; height: 68px; border-radius: 50%; border: 5px solid #fff; background: #fff; cursor: pointer; box-shadow: 0 0 0 3px rgba(255,255,255,0.3); }
.cam__shutter:active { transform: scale(0.94); }
.chamada { position: fixed; inset: 0; z-index: 400; background: var(--bg, #081126); color: var(--text); display: flex; flex-direction: column; }
.chamada__top { display: flex; align-items: center; gap: var(--space-4); padding: var(--space-5) var(--space-8); border-bottom: 1px solid var(--border); }
.chamada__logo { height: 44px; width: auto; }
.chamada__title { font-size: 22px; font-weight: var(--fw-semibold); color: #ffffff; }
.chamada__voz { margin-left: auto; display: inline-flex; align-items: center; gap: var(--space-2); padding: 8px 14px; font-size: var(--text-sm); font-weight: var(--fw-medium); color: var(--text-secondary); background: rgba(245,245,245,0.06); border: 1px solid var(--border-strong); border-radius: var(--radius-full); cursor: pointer; transition: color var(--duration-fast) var(--ease), background var(--duration-fast) var(--ease); }
.chamada__voz:hover { color: #fff; }
.chamada__voz.is-on { color: #fff; background: var(--success); border-color: var(--success); }
.chamada__clock { margin-left: var(--space-5); font-family: var(--font-mono); font-size: 24px; color: var(--text-muted); }
.chamada__main { flex: 1; display: flex; align-items: center; justify-content: center; padding: var(--space-6); }
.chamada__idle { font-size: 7vh; color: #ffffff; font-weight: 600; }
.chamada__senha { display: flex; flex-direction: column; align-items: center; gap: 1.5vh; text-align: center; }
.chamada__prio { display: inline-flex; align-items: center; gap: var(--space-2); color: var(--warning); font-size: 3vh; font-weight: var(--fw-semibold); }
.chamada__lbl { font-size: 5.5vh; color: #ffffff; font-weight: 700; text-transform: uppercase; letter-spacing: 8px; }
.chamada__num { font-family: var(--font-mono); font-weight: 800; font-size: 44vh; line-height: 1; color: #ffffff; text-shadow: 0 4px 30px rgba(0,0,0,0.35); }
.chamada__nome { font-size: 6.5vh; font-weight: 600; color: #ffffff; }
.chamada__hist { display: flex; align-items: center; gap: var(--space-3); padding: var(--space-5) var(--space-8); border-top: 1px solid var(--border); min-height: 9vh; }
.chamada__histlbl { color: var(--text-muted); font-size: 14px; text-transform: uppercase; letter-spacing: 2px; }
.chamada__histitem { font-family: var(--font-mono); font-size: 24px; font-weight: 600; color: var(--text-secondary); padding: 4px 14px; border: 1px solid var(--border); border-radius: var(--radius-md); }
@keyframes chamadaFlash { 0% { transform: scale(0.96); opacity: .4; } 60% { transform: scale(1.03); } 100% { transform: scale(1); opacity: 1; } }
.chamada__senha.is-flash { animation: chamadaFlash .6s ease-out; }
@media (prefers-reduced-motion: reduce) { .chamada__senha.is-flash { animation: none; } }

/* ════════════════ PERFIL DO CIDADÃO (painel) ════════════════ */
.perfil__hero { display: flex; flex-direction: column; align-items: center; text-align: center; gap: var(--space-2); padding: var(--space-8) var(--space-5) var(--space-6); }
.perfil__avatarwrap { position: relative; margin-bottom: var(--space-2); }
.perfil__avatar { display: flex; align-items: center; justify-content: center; width: 96px; height: 96px; overflow: hidden; font-size: var(--text-4xl); font-weight: var(--fw-bold); color: var(--text-secondary); background: var(--bg-muted); border: 2px solid var(--border-strong); border-radius: var(--radius-full); }
.perfil__avatar img { width: 100%; height: 100%; object-fit: cover; }
.perfil__avatar.is-loading { opacity: 0.5; }
.perfil__avbtn { position: absolute; right: -2px; bottom: -2px; display: inline-flex; align-items: center; justify-content: center; width: 32px; height: 32px; color: var(--primary-text); background: var(--primary); border: 2px solid var(--bg); border-radius: var(--radius-full); cursor: pointer; }
.perfil__nome { font-size: var(--text-2xl); font-weight: var(--fw-bold); letter-spacing: var(--tracking-tight); }
.perfil__sub { font-size: var(--text-sm); color: var(--text-muted); }
.perfil__card { max-width: 640px; margin: 0 auto var(--space-5); padding: var(--space-6); background: var(--bg-muted); border: 1px solid var(--border); border-radius: var(--radius-2xl); }
.perfil__cardhead { display: flex; align-items: center; justify-content: space-between; gap: var(--space-3); margin-bottom: var(--space-4); }
.perfil__cardtitle { font-size: var(--text-lg); font-weight: var(--fw-semibold); }
.perfil__rows { display: flex; flex-direction: column; }
.perfil__row { display: flex; align-items: center; justify-content: space-between; gap: var(--space-4); padding: var(--space-3) 0; font-size: var(--text-sm); border-bottom: 1px solid var(--border-subtle); }
.perfil__row:last-child { border-bottom: 0; }
.perfil__lbl { display: inline-flex; align-items: center; gap: var(--space-1); color: var(--text-muted); }
.perfil__lock { display: inline-flex; align-items: center; gap: 3px; margin-left: var(--space-2); font-size: 10px; font-weight: var(--fw-regular); text-transform: uppercase; letter-spacing: var(--tracking-wide); color: var(--text-subtle); }
.md__proto { font-family: var(--font-mono); font-weight: var(--fw-semibold); }
.md__nome { display: block; font-size: var(--text-sm); color: var(--text-muted); margin-top: 2px; }

/* ════════════════ PAINEL ADMIN (edição da landing) ════════════════ */
.adm { display: grid; grid-template-columns: 1fr; grid-template-rows: auto auto 1fr; min-height: 100dvh; }
.adm__topbar { display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: var(--space-3); padding: calc(var(--space-3) + var(--safe-top)) var(--space-5) var(--space-3); background: var(--brand-800); border-bottom: 1px solid var(--border); }
.adm__topbrand { display: flex; align-items: center; gap: var(--space-3); }
.adm__toplogo { height: 34px; width: auto; object-fit: contain; }
.adm__topname { font-size: var(--text-xs); font-weight: var(--fw-semibold); letter-spacing: var(--tracking-wide); text-transform: uppercase; color: var(--text-secondary); }
.adm__topver { font-size: var(--text-xs); font-weight: var(--fw-medium); color: var(--text-subtle); padding: 2px var(--space-2); border: 1px solid var(--border); border-radius: var(--radius-full); }
.adm__topuser { display: inline-flex; align-items: center; gap: var(--space-2); font-size: var(--text-sm); font-weight: var(--fw-medium); color: var(--text-secondary); padding-right: var(--space-2); }
.adm__dash { display: flex; flex-direction: column; gap: var(--space-5); max-width: 760px; }
.adm__kpis { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--space-3); }
.adm__kpi { display: flex; flex-direction: column; gap: 4px; padding: var(--space-4); background: var(--bg-muted); border: 1px solid var(--border); border-radius: var(--radius-lg); }
.adm__kpinum { font-size: 28px; font-weight: 700; color: var(--text); line-height: 1.1; }
.adm__kpilbl { font-size: var(--text-xs); color: var(--text-muted); }
.adm__bars { display: flex; flex-direction: column; gap: var(--space-2); }
.adm__bar { display: flex; align-items: center; gap: var(--space-3); font-size: var(--text-sm); }
.adm__barlbl { width: 140px; color: var(--text-secondary); flex-shrink: 0; text-transform: capitalize; }
.adm__bartrack { flex: 1; height: 10px; background: var(--bg-subtle); border-radius: var(--radius-full); overflow: hidden; }
.adm__barfill { display: block; height: 100%; background: var(--brand-500, #1d4ed8); border-radius: var(--radius-full); }
.adm__barfill--alt { background: var(--success, #34d399); }
.adm__barn { width: 32px; text-align: right; color: var(--text); font-weight: var(--fw-semibold); }
@media (min-width: 720px) { .adm__kpis { grid-template-columns: repeat(4, 1fr); } }
.adm__chartwrap { background: var(--bg-muted); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: var(--space-3); }
.adm__chart { width: 100%; height: auto; display: block; }
.adm__chgrid { stroke: var(--border); stroke-width: 1; stroke-dasharray: 2 4; }
.adm__charea { opacity: 0; animation: admFade .6s ease-out .3s forwards; }
.adm__chline { stroke: var(--success, #34d399); stroke-width: 2.4; stroke-linejoin: round; stroke-linecap: round; stroke-dasharray: 1600; stroke-dashoffset: 1600; animation: admDraw 1.3s ease-out forwards; }
.adm__chdot { fill: var(--bg-muted); stroke: var(--success, #34d399); stroke-width: 2; animation: admUp .5s ease-out .9s backwards; }
.adm__chdot.is-now { fill: var(--success, #34d399); stroke: var(--text); }
.adm__chval { fill: var(--text-secondary); font-size: 10px; font-weight: 600; text-anchor: middle; }
.adm__chlbl { fill: var(--text-secondary); font-size: 10px; text-anchor: middle; text-transform: capitalize; }
@keyframes admDraw { to { stroke-dashoffset: 0; } }
@keyframes admFade { to { opacity: 1; } }
@keyframes admUp { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: none; } }
@media (prefers-reduced-motion: reduce) { .adm__chline { animation: none; stroke-dashoffset: 0; } .adm__charea, .adm__chdot { animation: none; opacity: 1; } }
.adm__topactions { display: flex; gap: var(--space-2); }
.adm__side { display: flex; flex-direction: column; gap: var(--space-3); padding: var(--space-4); background: var(--bg-subtle); border-bottom: 1px solid var(--border); }
.adm__group { display: none; padding: var(--space-3) var(--space-3) var(--space-1); font-size: var(--text-xs); font-weight: var(--fw-medium); text-transform: uppercase; letter-spacing: var(--tracking-wide); color: var(--text-subtle); }
.adm__soon { margin-left: auto; padding: 1px 6px; font-size: 10px; text-transform: uppercase; letter-spacing: var(--tracking-wide); color: var(--text-subtle); background: var(--bg-muted); border: 1px solid var(--border); border-radius: var(--radius-full); }
.adm__navitem.is-disabled { opacity: 0.5; cursor: default; }
.adm__navitem.is-disabled:hover { background: none; color: var(--text-secondary); }
.adm__nav { display: flex; gap: var(--space-1); overflow-x: auto; scrollbar-width: none; }
.adm__nav::-webkit-scrollbar { display: none; }
.adm__navitem { display: inline-flex; align-items: center; gap: var(--space-2); white-space: nowrap; padding: var(--space-2) var(--space-3); font-size: var(--text-sm); font-weight: var(--fw-medium); color: var(--text-secondary); border-radius: var(--radius-md); transition: background var(--duration-fast) var(--ease), color var(--duration-fast) var(--ease); }
.adm__navitem:hover { color: var(--text); background: var(--bg-muted); }
.adm__navitem.is-active { color: var(--text); background: var(--primary-subtle); }
.adm__sidefoot { display: flex; gap: var(--space-4); }
.adm__link { display: inline-flex; align-items: center; gap: var(--space-1); font-size: var(--text-sm); color: var(--text-secondary); }
.adm__link:hover { color: var(--text); }
.adm__main { position: relative; padding: var(--space-6); }
.adm__top { display: flex; align-items: flex-end; justify-content: space-between; gap: var(--space-4); margin-bottom: var(--space-6); }
.adm__crumb { font-size: var(--text-xs); text-transform: uppercase; letter-spacing: var(--tracking-wide); color: var(--text-muted); }
.adm__title { font-size: var(--text-2xl); font-weight: var(--fw-bold); letter-spacing: var(--tracking-tight); }
.adm__actions { display: flex; gap: var(--space-2); }
.adm__pager { display: flex; flex-wrap: wrap; gap: var(--space-2); margin-bottom: var(--space-6); padding-bottom: var(--space-5); border-bottom: 1px solid var(--border-subtle); }
.adm__page { display: inline-flex; align-items: center; gap: var(--space-2); padding: var(--space-2) var(--space-4); font-size: var(--text-sm); font-weight: var(--fw-medium); color: var(--text-secondary); background: var(--bg-muted); border: 1px solid var(--border); border-radius: var(--radius-full); transition: color var(--duration-fast) var(--ease), background var(--duration-fast) var(--ease), border-color var(--duration-fast) var(--ease); }
.adm__page:hover { color: var(--text); border-color: var(--border-strong); }
.adm__page.is-active { color: var(--primary-text); background: var(--primary); border-color: var(--primary); }
.adm__panel { display: flex; flex-direction: column; gap: var(--space-4); max-width: 640px; }
.adm__list { display: flex; flex-direction: column; gap: var(--space-4); margin-top: var(--space-2); }
.adm__listtitle { font-size: var(--text-sm); text-transform: uppercase; letter-spacing: var(--tracking-wide); color: var(--text-muted); }
.adm__card { display: flex; flex-direction: column; gap: var(--space-3); padding: var(--space-4); background: var(--bg-muted); border: 1px solid var(--border); border-radius: var(--radius-lg); }
.adm__cardhead { display: flex; align-items: center; justify-content: space-between; gap: var(--space-3); }
.adm__del { display: inline-flex; align-items: center; gap: var(--space-1); font-size: var(--text-xs); font-weight: var(--fw-medium); color: var(--danger); }
.adm__del:hover { text-decoration: underline; }
.adm__subpager { display: flex; flex-wrap: wrap; gap: var(--space-2); margin-bottom: var(--space-3); }
.adm__chip { display: inline-flex; align-items: center; justify-content: center; gap: var(--space-1); min-width: 34px; padding: var(--space-1) var(--space-3); font-size: var(--text-sm); font-weight: var(--fw-medium); color: var(--text-secondary); background: var(--bg); border: 1px solid var(--border); border-radius: var(--radius-full); transition: color var(--duration-fast) var(--ease), background var(--duration-fast) var(--ease), border-color var(--duration-fast) var(--ease); }
.adm__chip:hover { color: var(--text); border-color: var(--border-strong); }
.adm__chip.is-active { color: var(--primary-text); background: var(--primary); border-color: var(--primary); }
.adm__chip--add { color: var(--text); border-style: dashed; }
.adm__img { display: flex; gap: var(--space-4); align-items: flex-start; }
.adm__imgprev { width: 132px; height: 84px; flex: none; object-fit: cover; background: var(--bg-subtle); border: 1px solid var(--border); border-radius: var(--radius-md); }
.adm__imgactions { display: flex; flex-direction: column; gap: var(--space-2); flex: 1; min-width: 0; }
.adm__imgactions .btn { align-self: flex-start; }
.adm__toggle { display: flex; align-items: center; gap: var(--space-2); font-size: var(--text-sm); color: var(--text-secondary); cursor: pointer; }
.adm__toast { position: fixed; left: 50%; bottom: var(--space-6); transform: translate(-50%, 20px); z-index: var(--z-toast); padding: var(--space-3) var(--space-5); font-size: var(--text-sm); color: var(--text); background: var(--success-bg); border: 1px solid var(--success-border); border-radius: var(--radius-full); opacity: 0; pointer-events: none; transition: opacity var(--duration) var(--ease), transform var(--duration) var(--ease); }
.adm__toast.is-show { opacity: 1; transform: translate(-50%, 0); }

/* Cadastros recebidos (atendimento) */
.adm__search { display: flex; align-items: center; gap: var(--space-2); margin-bottom: var(--space-5); padding-left: var(--space-3); color: var(--text-muted); background: var(--bg-muted); border: 1px solid var(--border-strong); border-radius: var(--radius-lg); }
.adm__search .field__control { flex: 1; min-height: 44px; border: 0; background: transparent; }
.adm__cadrows { display: flex; flex-direction: column; gap: var(--space-2); }
.adm__cadrow { display: flex; align-items: center; justify-content: space-between; gap: var(--space-3); width: 100%; padding: var(--space-3) var(--space-4); text-align: left; background: var(--bg-muted); border: 1px solid var(--border); border-radius: var(--radius-lg); transition: border-color var(--duration-fast) var(--ease); }
.adm__cadrow:hover { border-color: var(--border-strong); }
.adm__cadinfo { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.adm__cadnome { font-size: var(--text-sm); font-weight: var(--fw-semibold); color: var(--text); }
.adm__cadmeta { font-size: var(--text-xs); color: var(--text-muted); }
.adm__flag { display: flex; align-items: flex-start; gap: var(--space-2); max-width: 560px; margin-bottom: var(--space-5); padding: var(--space-3) var(--space-4); font-size: var(--text-sm); color: var(--text); background: var(--warning-bg); border: 1px solid var(--warning-border); border-radius: var(--radius-md); }
.adm__flag i { color: var(--warning); flex-shrink: 0; margin-top: 2px; }
.adm__flag--ok { background: var(--success-bg); border-color: var(--success-border); }
.adm__flag--ok i { color: var(--success); }
.adm__senhabox { font-family: var(--font-mono); font-size: var(--text-base); font-weight: var(--fw-semibold); color: var(--text); background: var(--bg-muted); padding: 2px var(--space-2); border-radius: var(--radius-sm); }
.field__pass { position: relative; display: block; }
.field__pass .field__control { padding-right: 44px; }
.field__eye { position: absolute; right: 6px; top: 50%; transform: translateY(-50%); display: inline-flex; align-items: center; justify-content: center; width: 32px; height: 32px; padding: 0; border: 0; background: transparent; color: var(--text-muted); cursor: pointer; border-radius: var(--radius-sm); }
.field__eye:hover { color: var(--text); }
.adm__members { display: flex; flex-direction: column; gap: var(--space-2); max-width: 560px; margin-bottom: var(--space-6); }
.adm__memrow { padding: var(--space-3) var(--space-4); background: var(--bg-subtle); border: 1px solid var(--border); border-radius: var(--radius-md); }
.adm__meminfo { display: flex; flex-direction: column; gap: 2px; }
.adm__memnome { font-weight: var(--fw-semibold); font-size: var(--text-sm); color: var(--text); }
.adm__memrel { font-weight: 400; color: var(--text-muted); text-transform: lowercase; }
.adm__memmeta { font-size: var(--text-xs); color: var(--text-secondary); }
.adm__membadge { display: inline-block; padding: 1px var(--space-2); font-weight: var(--fw-medium); color: var(--warning); background: var(--warning-bg); border-radius: var(--radius-full); }
.adm__staffrow { display: flex; align-items: center; justify-content: space-between; gap: var(--space-3); flex-wrap: wrap; }
.adm__memacts { display: inline-flex; gap: var(--space-2); flex-wrap: wrap; }
/* Fila de atendimento: fontes maiores p/ leitura rápida do servidor */
.adm__filarow { padding: var(--space-4) var(--space-5); }
.adm__filarow .adm__memnome { font-size: var(--text-xl); font-weight: var(--fw-bold); }
.adm__filarow .adm__memmeta { font-size: var(--text-base); color: var(--text-secondary); }
.adm__filarow .adm__membadge { font-size: var(--text-sm); }
/* Quadro de atendimento (kanban) */
.adm__board { display: grid; grid-template-columns: 1fr; gap: var(--space-4); }
@media (min-width: 880px) { .adm__board { grid-template-columns: repeat(4, minmax(0, 1fr)); align-items: start; } }
.adm__col { background: var(--bg-subtle); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: var(--space-3); }
.adm__coltitle { display: flex; align-items: center; justify-content: space-between; gap: var(--space-2); margin: 0 0 var(--space-3); font-size: var(--text-sm); font-weight: var(--fw-semibold); text-transform: uppercase; letter-spacing: var(--tracking-wide); color: var(--text-muted); }
.adm__colcount { display: inline-flex; align-items: center; justify-content: center; min-width: 22px; height: 22px; padding: 0 6px; font-size: var(--text-xs); font-weight: var(--fw-bold); color: var(--text); background: var(--bg-muted); border: 1px solid var(--border); border-radius: var(--radius-full); }
.adm__colvazio { text-align: center; padding: var(--space-4) 0; }
.adm__panel--board { max-width: none; }
.adm__board .adm__filarow { flex-direction: column; align-items: stretch; gap: var(--space-2); padding: var(--space-3); }
.adm__board .adm__memacts { width: 100%; flex-direction: column; align-items: stretch; gap: var(--space-2); }
.adm__board .adm__memacts .btn { width: 100%; justify-content: center; }
/* Edição do cadastro no atendimento */
.adm__editgrid { display: grid; grid-template-columns: 1fr; gap: var(--space-3); margin-bottom: var(--space-5); }
@media (min-width: 620px) { .adm__editgrid { grid-template-columns: 1fr 1fr; } }
.adm__docadd { display: flex; align-items: center; gap: var(--space-3); flex-wrap: wrap; margin-top: var(--space-3); }
/* Editor de cargos (permissões) */
.adm__cargos { display: grid; grid-template-columns: 1fr; gap: var(--space-4); }
@media (min-width: 880px) { .adm__cargos { grid-template-columns: 1fr 1fr; } }
.adm__cargohead { display: flex; align-items: center; gap: var(--space-3); }
.adm__cargonome { font-weight: var(--fw-semibold); }
.adm__perms { display: flex; flex-direction: column; gap: var(--space-2); margin-top: var(--space-2); }
.adm__permrow { display: flex; align-items: center; gap: var(--space-2); font-size: var(--text-sm); color: var(--text); cursor: pointer; }
.adm__permrow input { width: 18px; height: 18px; flex-shrink: 0; accent-color: var(--success); }
/* Sanfona de permissões (grupos fecháveis) */
.adm__permacc { display: flex; flex-direction: column; gap: var(--space-2); margin-top: var(--space-2); }
.adm__permgrp { border: 1px solid var(--border); border-radius: var(--radius-md); overflow: hidden; }
.adm__permgrphead { display: flex; align-items: center; gap: var(--space-2); width: 100%; padding: var(--space-3) var(--space-4); font-size: var(--text-sm); font-weight: var(--fw-semibold); color: var(--text); background: var(--bg-muted); border: 0; cursor: pointer; text-align: left; }
.adm__permgrphead:hover { background: var(--bg-subtle); }
.adm__permgrp .adm__perms { margin: 0; padding: var(--space-2) var(--space-4) var(--space-4); }
/* Chat da equipe */
.adm__chat2 { display: grid; grid-template-columns: 1fr; gap: var(--space-3); height: calc(100dvh - 200px); min-height: 380px; }
@media (min-width: 760px) { .adm__chat2 { grid-template-columns: 240px 1fr; } }
.adm__chatlist { display: flex; flex-direction: column; gap: 2px; overflow-y: auto; padding: var(--space-2); background: var(--bg-subtle); border: 1px solid var(--border); border-radius: var(--radius-lg); max-height: 160px; }
@media (min-width: 760px) { .adm__chatlist { max-height: none; } }
.adm__chatlistitem { display: flex; align-items: center; gap: var(--space-2); width: 100%; padding: var(--space-2) var(--space-3); font-size: var(--text-sm); color: var(--text-secondary); background: none; border: 0; border-radius: var(--radius-md); cursor: pointer; text-align: left; }
.adm__chatlistitem:hover { background: var(--bg-muted); color: var(--text); }
.adm__chatlistitem.is-active { background: var(--primary-subtle); color: var(--text); font-weight: var(--fw-medium); }
.adm__chatlistitem span { flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.adm__chatbadge { flex: 0 0 auto; min-width: 20px; height: 20px; padding: 0 6px; display: inline-flex; align-items: center; justify-content: center; font-size: 11px; font-weight: var(--fw-bold); line-height: 1; color: #fff; background: var(--danger, #dc2626); border-radius: 999px; }
.adm__chatlistlbl { font-size: var(--text-xs); text-transform: uppercase; letter-spacing: var(--tracking-wide); color: var(--text-muted); padding: var(--space-3) var(--space-3) var(--space-1); }
.adm__chatlisthint { padding: 0 var(--space-3); }
.adm__chatpane { display: flex; flex-direction: column; min-width: 0; }
.adm__chathead { font-weight: var(--fw-semibold); color: var(--text); padding: 0 0 var(--space-2); }
.adm__chat { display: flex; flex-direction: column; height: calc(100dvh - 220px); min-height: 360px; max-width: 760px; }
.adm__chatmsgs { flex: 1; overflow-y: auto; display: flex; flex-direction: column; gap: var(--space-2); padding: var(--space-4); background: var(--bg-subtle); border: 1px solid var(--border); border-radius: var(--radius-lg); }
.adm__chatmsg { display: flex; }
.adm__chatmsg--me { justify-content: flex-end; }
.adm__chatbubble { display: flex; flex-direction: column; gap: 2px; max-width: 78%; padding: var(--space-2) var(--space-3); background: var(--bg-muted); border: 1px solid var(--border); border-radius: var(--radius-lg); }
.adm__chatmsg--me .adm__chatbubble { background: var(--primary-subtle); border-color: var(--primary-border); }
.adm__chatautor { font-size: var(--text-xs); font-weight: var(--fw-semibold); color: var(--primary); }
.adm__chattexto { font-size: var(--text-sm); color: var(--text); overflow-wrap: anywhere; white-space: pre-wrap; }
.adm__chathora { font-size: 11px; color: var(--text-muted); align-self: flex-end; }
.adm__chatinput { display: flex; gap: var(--space-2); margin-top: var(--space-3); }
.adm__chatinput .field__control { flex: 1; }
.adm__cargosel { max-width: 220px; }
.adm__prog { height: 4px; width: 100%; margin: var(--space-3) 0; background: var(--bg-subtle); border-radius: var(--radius-full); overflow: hidden; }
.adm__prog span { display: block; height: 100%; width: 40%; background: var(--primary); border-radius: var(--radius-full); animation: admProg 1s ease-in-out infinite; }
@keyframes admProg { 0% { margin-left: -40%; } 100% { margin-left: 100%; } }
.adm__cargoone { margin-top: var(--space-4); max-width: 560px; }
/* Central de e-mails */
.adm__emailgrid { display: grid; grid-template-columns: 1fr; gap: var(--space-5); margin-top: var(--space-4); }
@media (min-width: 880px) { .adm__emailgrid { grid-template-columns: 1fr 1fr; align-items: start; } }
.adm__emailedit { display: flex; flex-direction: column; gap: var(--space-3); }
.adm__phrow { display: flex; align-items: center; gap: var(--space-2); flex-wrap: wrap; }
.adm__emailprevwrap { display: flex; flex-direction: column; gap: var(--space-2); }
.adm__emailprev { background: var(--bg-muted); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: var(--space-4); }
.adm__emailprevsub { font-size: var(--text-sm); color: var(--text); margin-bottom: var(--space-3); padding-bottom: var(--space-3); border-bottom: 1px solid var(--border-subtle); }
.adm__emailprevbody { font-size: var(--text-sm); color: var(--text-secondary); line-height: 1.6; }
.adm__emailprevbody p { margin: 0 0 var(--space-2); }
.adm__permpick { display: flex; gap: var(--space-3); align-items: center; flex-wrap: wrap; max-width: 600px; }
.adm__permpick select { flex: 1; min-width: 240px; }
.auth__link { display: inline-flex; align-items: center; gap: var(--space-2); margin-top: var(--space-4); font-size: var(--text-sm); font-weight: var(--fw-medium); color: var(--text-secondary); background: none; border: 0; cursor: pointer; }
.auth__link:hover { color: var(--text); text-decoration: underline; }
.adm__panel--wide { max-width: none; }
.adm__staffgrid { display: grid; grid-template-columns: 1fr; gap: var(--space-3); max-width: none; }
@media (min-width: 880px) { .adm__staffgrid { grid-template-columns: 1fr 1fr; } }
.adm__staffcard { flex-direction: column; align-items: stretch; gap: var(--space-3); padding: var(--space-4); }
.adm__staffcard .adm__memacts { flex-wrap: wrap; }
/* Painel de tirar senha */
.adm__tirar { display: flex; flex-direction: column; gap: var(--space-4); max-width: 560px; }
.adm__tirargrid { display: grid; grid-template-columns: 1fr; gap: var(--space-3); }
@media (min-width: 620px) { .adm__tirargrid { grid-template-columns: 1fr 1fr; } }
.adm__tiraracts { margin-top: var(--space-2); }
.adm__tiraracts .btn { width: 100%; justify-content: center; font-size: var(--text-base); padding: var(--space-3) var(--space-5); }

/* Painel do programador (manutenção técnica) — menu lateral + conteúdo ao lado */
.prog { max-width: 1040px; }
.prog__navlbl { flex: 1; text-align: left; }
.prog__navlock { color: var(--text-subtle); flex-shrink: 0; }
.prog__soon { display: flex; flex-direction: column; align-items: flex-start; gap: var(--space-3); max-width: 560px; padding: var(--space-6); background: var(--bg-muted); border: 1px dashed var(--border-strong); border-radius: var(--radius-lg); }
.prog__soonicon { display: inline-flex; align-items: center; justify-content: center; width: 48px; height: 48px; color: var(--text-secondary); background: var(--bg); border: 1px solid var(--border); border-radius: var(--radius-md); }
.prog__soonbadge { padding: 2px var(--space-3); font-size: var(--text-xs); font-weight: var(--fw-semibold); text-transform: uppercase; letter-spacing: var(--tracking-wide); color: var(--warning); background: var(--warning-bg); border-radius: var(--radius-full); }
.prog__soontitle { font-size: var(--text-lg); font-weight: var(--fw-semibold); color: var(--text); }
.prog__soondesc { font-size: var(--text-sm); color: var(--text-secondary); line-height: 1.6; }
.prog__lgpd { max-width: 640px; }
.prog__switch { display: inline-flex; align-items: center; gap: var(--space-3); cursor: pointer; user-select: none; margin-bottom: var(--space-2); }
.prog__switch input { position: absolute; width: 1px; height: 1px; opacity: 0; }
.prog__switchtrack { position: relative; width: 42px; height: 24px; flex-shrink: 0; background: var(--border-strong); border-radius: var(--radius-full); transition: background var(--duration-fast) var(--ease); }
.prog__switchtrack::after { content: ''; position: absolute; top: 2px; left: 2px; width: 20px; height: 20px; background: #fff; border-radius: 50%; transition: transform var(--duration-fast) var(--ease); }
.prog__switch input:checked + .prog__switchtrack { background: var(--success); }
.prog__switch input:checked + .prog__switchtrack::after { transform: translateX(18px); }
.prog__switch input:focus-visible + .prog__switchtrack { box-shadow: 0 0 0 3px var(--primary-subtle); }
.prog__switchlbl { font-size: var(--text-sm); color: var(--text); }
.prog__logs { display: flex; flex-direction: column; gap: var(--space-2); }
.prog__log { display: flex; align-items: flex-start; gap: var(--space-3); padding: var(--space-3) var(--space-4); background: var(--bg-muted); border: 1px solid var(--border); border-radius: var(--radius-md); }
.prog__logico { display: inline-flex; align-items: center; justify-content: center; width: 32px; height: 32px; flex-shrink: 0; color: var(--text-secondary); background: var(--bg); border: 1px solid var(--border); border-radius: var(--radius-md); }
.prog__logbody { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.prog__logrot { font-size: var(--text-sm); font-weight: var(--fw-medium); color: var(--text); }
.prog__logmeta { font-size: var(--text-xs); color: var(--text-muted); }
.prog__logsrv { width: 12px; height: 12px; vertical-align: -1px; color: var(--success); }

/* Banner global de aviso (flags) */
.ns-banner { background: var(--warning-bg); border-bottom: 1px solid var(--warning-border); color: var(--text); }
.ns-banner[hidden] { display: none; }
.ns-banner__in { max-width: 1100px; margin: 0 auto; padding: var(--space-3) var(--space-5); font-size: var(--text-sm); font-weight: var(--fw-medium); line-height: 1.5; text-align: center; }

/* Tela de modo manutenção */
.maint { min-height: 100vh; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: var(--space-4); padding: var(--space-6) var(--space-5); text-align: center; }
.maint__logo { width: 84px; height: auto; }
.maint__title { font-size: var(--text-2xl); font-weight: var(--fw-bold); color: var(--text); }
.maint__msg { max-width: 50ch; color: var(--text-secondary); line-height: 1.6; }
.prog__sec { margin-bottom: var(--space-6); }
.prog__sectitle { display: flex; align-items: center; gap: var(--space-2); margin-bottom: var(--space-4); font-size: var(--text-xs); font-weight: var(--fw-semibold); text-transform: uppercase; letter-spacing: var(--tracking-wide); color: var(--text-muted); }
.prog__sectitle i { color: var(--text-secondary); }
.prog__grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: var(--space-3); }
.prog__health { display: flex; align-items: center; gap: var(--space-3); padding: var(--space-3) var(--space-4); background: var(--bg-muted); border: 1px solid var(--border); border-radius: var(--radius-lg); }
.prog__hicon { display: inline-flex; align-items: center; justify-content: center; width: 34px; height: 34px; flex-shrink: 0; color: var(--text-secondary); background: var(--bg); border: 1px solid var(--border); border-radius: var(--radius-md); }
.prog__hbody { display: flex; flex-direction: column; gap: 2px; min-width: 0; flex: 1; }
.prog__hlabel { font-size: var(--text-xs); color: var(--text-muted); }
.prog__hval { font-size: var(--text-sm); font-weight: var(--fw-medium); color: var(--text); overflow-wrap: anywhere; }
.prog__hdot { width: 9px; height: 9px; flex-shrink: 0; border-radius: var(--radius-full); background: var(--text-subtle); }
.prog__health--ok .prog__hdot { background: var(--success); }
.prog__health--warn .prog__hdot { background: var(--warning); }
.prog__health--bad .prog__hdot { background: var(--danger); }
.prog__health--info .prog__hdot { background: var(--primary); }
.prog__health--wait .prog__hdot { animation: progPulse 1s ease-in-out infinite; }
@keyframes progPulse { 0%, 100% { opacity: .3; } 50% { opacity: 1; } }
.prog__tools { display: flex; flex-direction: column; gap: var(--space-4); }
/* No desktop os cartões ficam lado a lado (2 colunas), não empilhados pra baixo. */
@media (min-width: 880px) {
  .prog__tools { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); align-items: start; }
  .prog__tools > .prog__toolacts { grid-column: 1 / -1; }
}
.prog__toolhead { display: flex; align-items: center; justify-content: space-between; gap: var(--space-3); }
.prog__toolname { display: inline-flex; align-items: center; gap: var(--space-2); font-size: var(--text-base); font-weight: var(--fw-semibold); color: var(--text); }
.prog__toolacts { display: flex; align-items: center; gap: var(--space-3); flex-wrap: wrap; }
.prog__inlineflag { margin-bottom: 0; }
@media (min-width: 880px) { .prog__spanfull { grid-column: 1 / -1; } }
.prog__badge { flex-shrink: 0; padding: 2px var(--space-3); font-size: var(--text-xs); font-weight: var(--fw-medium); border-radius: var(--radius-full); }
.prog__badge--auto { color: var(--primary); background: var(--primary-subtle); }
.prog__badge--manual { color: var(--text-muted); background: var(--bg-subtle); border: 1px solid var(--border); }
.prog__json { max-height: 360px; overflow: auto; margin: 0; padding: var(--space-4); font-family: var(--font-mono); font-size: var(--text-xs); line-height: 1.6; color: var(--text); background: var(--bg); border: 1px solid var(--border); border-radius: var(--radius-md); white-space: pre; }

/* No desktop tem espaço: aumenta botões e textos do painel. No celular fica compacto. */
@media (min-width: 880px) {
  .adm__title { font-size: 28px; }
  .adm__crumb { font-size: var(--text-sm); }
  .adm__navitem { font-size: 15px; padding: var(--space-3) var(--space-4); }
  .adm__group { font-size: var(--text-sm); }
  .adm .btn--sm { font-size: 14px; padding: 9px 16px; }
  .adm__cadnome, .adm__memnome { font-size: 16px; }
  .adm__cadmeta, .adm__memmeta { font-size: 14px; }
  .adm__listtitle { font-size: 17px; }
  .adm__kpinum { font-size: 34px; }
  .adm .field__control { font-size: 15px; }
}
.adm__caddet { display: flex; flex-direction: column; gap: var(--space-4); max-width: 560px; margin-bottom: var(--space-6); }
.adm__docs { display: flex; flex-direction: column; gap: var(--space-2); }
.adm__doclink { display: inline-flex; align-items: center; gap: var(--space-2); font-size: var(--text-sm); color: var(--info); }
.adm__doclink.is-off { color: var(--text-muted); }
.adm__linkback { display: inline-flex; align-items: center; gap: 4px; margin-bottom: var(--space-1); font-size: var(--text-xs); text-transform: uppercase; letter-spacing: var(--tracking-wide); color: var(--text-secondary); }
.adm__linkback:hover { color: var(--text); }
@media (min-width: 880px) {
  .adm { grid-template-columns: 248px 1fr; grid-template-rows: auto 1fr; }
  .adm__topbar { grid-column: 1 / -1; }
  .adm__side { grid-row: 2; border-bottom: none; border-right: 1px solid var(--border); }
  .adm__main { grid-row: 2; }
  .adm__nav { flex-direction: column; overflow: visible; }
  .adm__group { display: block; }
  .adm__sidefoot { flex-direction: column; margin-top: auto; }
}

/* ════════════════ PAINEL (dashboard do servidor) ════════════════ */
/* Shell de servidor — menu persistente embaixo, conteúdo rolável (keep-alive). */
.shell { display: block; position: relative; }
/* Marca d'água da Prefeitura — ghost fixo atrás das telas internas (sobre o navy).
   Fixed = fica parado enquanto o conteúdo rola (look institucional). Os heróis das
   páginas têm gradiente sólido, então a marca só aparece na área de conteúdo. */
.shell::before { content: ''; position: fixed; inset: 0; z-index: 0; pointer-events: none;
  background: url(/assets/img/logo-prefeitura-branca.png) no-repeat center 96% / min(300px, 56vw) auto;
  opacity: .05; }
.shell__scroll { display: block; position: relative; z-index: 1; }
.view { display: block; }

.painel { max-width: 520px; margin: 0 auto; padding-bottom: calc(92px + var(--safe-bottom)); }
/* Desktop: telas internas "estilo site" (mais largas). Mobile-first intacto. Dashboard tem largura própria. */
@media (min-width: 768px) {
  .painel { max-width: 900px; }
  /* "Tela cheia" igual ao painel do Alex — todas as telas internas espalham pela página. */
  .painel.painel--wide { max-width: 1200px; }
}

/* "Organizar": as seções FLUEM em 2 colunas preenchendo os vazios (estilo masonry, sem buracos).
   Usa CSS multi-column: o cabeçalho/intro/ações ocupam a largura toda (column-span: all) e cada
   seção fica inteira numa coluna (break-inside: avoid). */
@media (min-width: 900px) {
  .painel--cols2 { column-count: 2; column-gap: var(--space-6); }
  .painel--cols2 > .staff-hero,
  .painel--cols2 > .screen-hint,
  .painel--cols2 > .admin__intro,
  .painel--cols2 > .lpedit__actions { column-span: all; }
  .painel--cols2 > .painel__section { break-inside: avoid; }

  /* Serviços/módulos em grade de 2 colunas. */
  .painel--svc .modcat { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--space-3); }

  /* Atendimento: chamada ocupa a largura toda; "Próximas" e "Atendidas" fluem lado a lado embaixo. */
  .painel--atend { column-count: 2; column-gap: var(--space-6); }
  .painel--atend > .staff-hero,
  .painel--atend > .screen-hint,
  .painel--atend > a,
  .painel--atend > .call { column-span: all; }
  .painel--atend > .painel__section { break-inside: avoid; }

  /* Cadastro: campos em 3 colunas p/ preencher a largura. */
  .painel--cad .form-grid { grid-template-columns: repeat(3, 1fr); }
  /* Emitir senha: cartões de serviço em 4 colunas. */
  .painel--senha .choice-grid { grid-template-columns: repeat(4, 1fr); }
}
.painel__top { display: flex; align-items: center; justify-content: space-between; padding: calc(var(--space-4) + var(--safe-top)) var(--space-5) var(--space-2); }
.painel__hello { font-size: var(--text-sm); color: var(--text-muted); }
.painel__name { font-size: var(--text-lg); font-weight: var(--fw-bold); letter-spacing: var(--tracking-tight); }
.painel__avatar { display: flex; align-items: center; justify-content: center; width: 38px; height: 38px; font-weight: var(--fw-bold); color: var(--primary); background: var(--primary-subtle); border-radius: var(--radius-full); }
.painel__big { padding: var(--space-4) var(--space-5) var(--space-2); }
.painel__big-label { font-size: var(--text-sm); color: var(--text-muted); }
.painel__big-num { font-size: var(--text-5xl); font-weight: var(--fw-bold); letter-spacing: var(--tracking-tighter); line-height: 1; }
.painel__big-num small { font-size: var(--text-xl); color: var(--text-subtle); font-weight: var(--fw-semibold); }
.painel__qa { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-2); }
.painel__tiles { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--space-3); padding: var(--space-2) var(--space-5); }
@media (min-width: 520px) { .painel__tiles { grid-template-columns: repeat(4, 1fr); } }
.tile { display: flex; flex-direction: column; gap: var(--space-2); padding: var(--space-4); background: var(--bg-muted); border: 1px solid var(--border); border-radius: var(--radius-lg); box-shadow: var(--shadow-sm); }
.tile__ic { display: flex; align-items: center; justify-content: center; width: 30px; height: 30px; border-radius: 9px; }
.tile__ic.tile--wait { background: var(--warning-bg); color: var(--warning); }
.tile__ic.tile--att  { background: var(--info-bg);    color: var(--info); }
.tile__ic.tile--done { background: var(--success-bg); color: var(--success); }
.tile__ic.tile--miss { background: var(--danger-bg);  color: var(--danger); }
.tile__num { font-size: var(--text-2xl); font-weight: var(--fw-bold); letter-spacing: var(--tracking-tight); }
.tile__lbl { font-size: var(--text-xs); color: var(--text-muted); }

/* ════════════════ PAINEL DE CHAMADA (/atendimento) ════════════════ */
.call { text-align: center; padding: var(--space-4) var(--space-5) 0; }
.guiche-pick { display: flex; align-items: center; justify-content: center; gap: var(--space-2); margin-bottom: var(--space-5); }
.guiche-pick__label { font-size: var(--text-sm); color: var(--text-muted); margin-right: var(--space-1); }
.guiche-pick__btn { width: 42px; height: 42px; border-radius: var(--radius-full); border: 1px solid var(--border-strong); font-weight: var(--fw-semibold); color: var(--text-secondary); background: var(--bg); transition: all var(--duration-fast) var(--ease); }
.guiche-pick__btn.is-active { background: var(--primary); color: var(--primary-text); border-color: var(--primary); }
.call__card { padding: var(--space-8) var(--space-5); background: var(--primary-subtle); border: 1px solid var(--primary-border); border-radius: var(--radius-2xl); }
.call__lbl { font-size: var(--text-xs); letter-spacing: var(--tracking-wide); text-transform: uppercase; color: var(--text-secondary); }
.call__num { font-family: var(--font-mono); font-size: clamp(64px, 22vw, 100px); font-weight: var(--fw-bold); color: var(--primary); line-height: 1; letter-spacing: var(--tracking-tight); margin: var(--space-2) 0; }
.call__sub { font-size: var(--text-base); color: var(--text-secondary); }
.call__empty { font-size: var(--text-2xl); color: var(--text-subtle); font-weight: var(--fw-semibold); padding: var(--space-8) 0; }
.call__actions { display: grid; gap: var(--space-3); margin-top: var(--space-5); }
.call__actions--row { grid-template-columns: 1fr 1fr; }
.call__person { display: inline-flex; align-items: center; gap: var(--space-2); flex-wrap: wrap; justify-content: center; margin-top: var(--space-3); font-size: var(--text-sm); font-weight: var(--fw-semibold); color: var(--text); }
/* Formulário "Finalizar cadastro CadÚnico" (atendimento) */
.finform { text-align: left; background: var(--bg-muted); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: var(--space-4); margin-top: var(--space-4); }
.finform__head { display: flex; align-items: center; gap: var(--space-2); font-weight: var(--fw-semibold); color: var(--text); margin-bottom: var(--space-3); }
.finform .field { margin-bottom: var(--space-3); }
.finform__row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-3); }

/* Legenda explicativa sob o cabeçalho das telas de servidor */
.screen-hint { padding: 0 var(--space-5) var(--space-4); margin-top: calc(-1 * var(--space-1)); font-size: var(--text-sm); color: var(--text-secondary); }

/* ════════════════ ADMIN ════════════════ */
.admin__intro { padding: 0 var(--space-5) var(--space-4); font-size: var(--text-sm); color: var(--text-secondary); }
.admin__add { display: flex; gap: var(--space-2); margin-bottom: var(--space-4); }
.admin__add .field__control { flex: 1; }
.painel__section { padding: var(--space-4) var(--space-5); }
.painel__section-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: var(--space-2); }
.painel__section-head h2 { font-size: var(--text-base); font-weight: var(--fw-semibold); }

/* Tab-bar inferior (servidor) */
.apptabs { position: fixed; bottom: 0; left: 0; right: 0; z-index: var(--z-dropdown); display: flex; justify-content: space-around; max-width: 520px; margin: 0 auto; padding: var(--space-3) var(--space-2) calc(var(--space-3) + var(--safe-bottom)); background: rgba(12,24,48,0.96); backdrop-filter: blur(12px); border-top: 1px solid var(--border-subtle); }
.apptabs__item { display: flex; flex-direction: column; align-items: center; gap: 5px; min-width: 64px; padding: var(--space-2) var(--space-3); border-radius: var(--radius-md); font-size: 12px; font-weight: var(--fw-semibold, 600); color: var(--text-muted); transition: color .15s ease, background .15s ease; }
.apptabs__item .icon { width: 24px; height: 24px; }
.apptabs__item.is-active { color: var(--primary); background: rgba(255,255,255,.06); }
.apptabs__item.is-active .icon { transform: scale(1.06); }
/* Desktop: barra cobre toda a base da tela (full-width), itens distribuídos. Definido
   APÓS a regra base de propósito — media query não soma especificidade, então precisa
   vir depois p/ vencer o max-width:520px da base. */
@media (min-width: 768px) {
  .apptabs { max-width: none; justify-content: space-evenly; padding-left: var(--space-8); padding-right: var(--space-8); }
  .apptabs__item { flex: 0 1 160px; }
}

/* ════════════════ ESTADO VAZIO ════════════════ */
.empty-state { display: flex; flex-direction: column; align-items: center; gap: var(--space-3); padding: var(--space-12) var(--space-6); text-align: center; color: var(--text-muted); }
.empty-state__icon { color: var(--text-subtle); }
.empty-state__title { font-size: var(--text-lg); font-weight: var(--fw-medium); color: var(--text-secondary); }

/* ════════════════ WIZARD (Agendamento) ════════════════ */
.wizard { max-width: 640px; }
.wizard__back { display: inline-flex; align-items: center; gap: var(--space-2); margin-bottom: var(--space-5); font-size: var(--text-sm); font-weight: var(--fw-medium); color: var(--text-secondary); }
.wizard__back:hover { color: var(--text); }
.stepper { display: flex; gap: var(--space-2); margin-bottom: var(--space-8); }
.stepper__item { display: flex; flex-direction: column; align-items: center; gap: var(--space-2); flex: 1; text-align: center; }
.stepper__dot { display: inline-flex; align-items: center; justify-content: center; width: 32px; height: 32px; font-size: var(--text-sm); font-weight: var(--fw-semibold); color: var(--text-muted); background: var(--bg-muted); border-radius: var(--radius-full); transition: background var(--duration) var(--ease), color var(--duration) var(--ease); }
.stepper__label { font-size: 11px; color: var(--text-muted); }
.stepper__item.is-active .stepper__dot { color: var(--primary-text); background: var(--primary); }
.stepper__item.is-active .stepper__label { color: var(--text); font-weight: var(--fw-medium); }
.stepper__item.is-done .stepper__dot { color: var(--primary); background: var(--primary-subtle); }
@media (max-width: 479px) { .stepper__label { display: none; } }

.wizard__title { font-size: var(--text-2xl); letter-spacing: var(--tracking-tight); }
.wizard__sub { margin-top: var(--space-2); margin-bottom: var(--space-6); color: var(--text-secondary); }
.wizard__form { display: flex; flex-direction: column; gap: var(--space-5); }
.wizard__actions { display: flex; gap: var(--space-3); justify-content: space-between; margin-top: var(--space-6); }
.wizard__actions--center { justify-content: center; flex-wrap: wrap; }
.field__opt { font-weight: var(--fw-regular); color: var(--text-subtle); }

.choice-grid { display: grid; grid-template-columns: 1fr; gap: var(--space-3); }
@media (min-width: 560px) { .choice-grid { grid-template-columns: 1fr 1fr; } }
@media (min-width: 768px) { .choice-grid { grid-template-columns: repeat(3, 1fr); } }
.choice-grid--2 { grid-template-columns: 1fr 1fr; }
.choice { display: flex; flex-direction: column; align-items: flex-start; gap: var(--space-2); padding: var(--space-5); text-align: left; background: var(--bg-muted); border: 1px solid var(--border); border-radius: var(--radius-xl); transition: border-color var(--duration) var(--ease), box-shadow var(--duration) var(--ease), transform var(--duration) var(--ease); }
.choice:hover:not(.is-disabled) { border-color: var(--primary); box-shadow: var(--shadow-md); transform: translateY(-2px); }
.choice.is-disabled { opacity: 0.5; cursor: not-allowed; }
.choice.is-selected { border-color: var(--primary); background: var(--primary-subtle); box-shadow: 0 0 0 1px var(--primary); }
.choice__icon { display: inline-flex; align-items: center; justify-content: center; width: 44px; height: 44px; color: var(--primary); background: var(--primary-subtle); border-radius: var(--radius-lg); }
.choice__title { font-size: var(--text-base); font-weight: var(--fw-semibold); }
.choice__meta { font-size: var(--text-xs); color: var(--text-muted); }

.day-grid { display: grid; grid-template-columns: 1fr; gap: var(--space-2); max-height: 56vh; overflow-y: auto; padding-right: var(--space-1); }
@media (min-width: 560px) { .day-grid { grid-template-columns: 1fr 1fr; } }
.day { display: flex; flex-direction: column; gap: 2px; padding: var(--space-4) var(--space-5); text-align: left; background: var(--bg); border: 1px solid var(--border); border-radius: var(--radius-lg); transition: border-color var(--duration-fast) var(--ease), background var(--duration-fast) var(--ease); }
.day:hover:not(.is-disabled) { border-color: var(--primary); background: var(--primary-subtle); }
.day.is-disabled { opacity: 0.45; cursor: not-allowed; }
.day__long { font-size: var(--text-sm); font-weight: var(--fw-medium); text-transform: capitalize; }
.day__meta { font-size: var(--text-xs); color: var(--text-muted); }

.resumo { gap: 0; padding: var(--space-2) var(--space-5); }
.resumo__row { display: flex; align-items: center; justify-content: space-between; gap: var(--space-4); padding: var(--space-3) 0; font-size: var(--text-sm); }
.resumo__row + .resumo__row { border-top: 1px solid var(--border-subtle); }
.resumo__row span { color: var(--text-secondary); }

.protocolo-success { display: flex; flex-direction: column; align-items: center; text-align: center; max-width: 480px; margin: 0 auto; padding-top: var(--space-6); }
.protocolo-success__badge { display: inline-flex; align-items: center; justify-content: center; width: 72px; height: 72px; margin-bottom: var(--space-5); color: var(--success); background: var(--success-bg); border-radius: var(--radius-full); }
.protocolo-success__title { font-size: var(--text-3xl); letter-spacing: var(--tracking-tight); }
.protocolo-card { display: flex; flex-direction: column; align-items: center; gap: var(--space-3); width: 100%; margin: var(--space-6) 0; padding: var(--space-6); background: var(--primary-subtle); border: 1px dashed var(--primary-border); border-radius: var(--radius-2xl); }
.protocolo-card__label { font-size: var(--text-xs); text-transform: uppercase; letter-spacing: var(--tracking-wide); color: var(--text-secondary); }
.protocolo-card__num { font-size: var(--text-3xl); font-weight: var(--fw-bold); color: var(--primary); letter-spacing: var(--tracking-tight); }

/* ── Barra de progresso de navegação (anti-"trava": confirma que o toque foi lido
   enquanto a tela carrega). Só aparece se a navegação passar de ~120ms. ───────── */
body[data-loading="1"]::after {
  content: "";
  position: fixed;
  top: 0; left: 0;
  height: 3px; width: 40%;
  background: var(--accent-blue-600, #1d4ed8);
  box-shadow: 0 0 8px var(--accent-blue-600, #1d4ed8);
  z-index: 9999;
  pointer-events: none;
  animation: semas-loadbar 0.9s ease-in-out infinite;
}
@keyframes semas-loadbar {
  0%   { left: -40%; width: 40%; }
  50%  { left: 30%;  width: 50%; }
  100% { left: 100%; width: 40%; }
}
@media (prefers-reduced-motion: reduce) {
  body[data-loading="1"]::after { animation: none; left: 0; width: 100%; opacity: .5; }
}

/* ── Permissões POR SERVIDOR (tela /permissoes — uma "ficha" por servidor) ───── */
.perm-user { background: var(--bg-muted, rgba(255,255,255,.03)); border: 1px solid var(--border); border-radius: var(--radius-2xl, 18px); padding: var(--space-4); margin-bottom: var(--space-4); }
.perm-user__head { display: flex; align-items: center; gap: var(--space-3); padding-bottom: var(--space-3); border-bottom: 1px solid var(--border); margin-bottom: var(--space-2); }
.perm-user__id { min-width: 0; display: flex; flex-direction: column; }
.perm-user__nome { font-weight: var(--fw-bold, 700); color: var(--text); }
.perm-user__sub { font-size: var(--text-xs); color: var(--text-secondary); }
.perm-user__grupo { margin-top: var(--space-3); }
.perm-user__gtit { font-size: var(--text-xs); text-transform: uppercase; letter-spacing: .1em; color: var(--text-secondary); margin: 0 0 var(--space-1); }
.perm-user__row { display: flex; align-items: center; justify-content: space-between; gap: var(--space-3); padding: var(--space-2) 0; }
.perm-user__lbl { font-size: var(--text-sm); color: var(--text); }
@media (min-width: 768px) {
  .perm-user__grupo { display: grid; grid-template-columns: 1fr 1fr; gap: 0 var(--space-6); align-items: start; }
  .perm-user__gtit { grid-column: 1 / -1; }
}

/* ───── Permissões 2.0 — busca + painel duplo (master-detail) ───── */
.perm2__stats { display: flex; flex-wrap: wrap; gap: var(--space-2); padding: 0 var(--space-5) var(--space-4); }
.perm2__stat { display: inline-flex; align-items: baseline; gap: 6px; padding: var(--space-1) var(--space-3); border: 1px solid var(--border); border-radius: 999px; font-size: var(--text-xs); color: var(--text-secondary); background: var(--bg-muted, rgba(255,255,255,.03)); }
.perm2__stat b { font-size: var(--text-sm); font-weight: var(--fw-bold); color: var(--text); }
.perm2__stat--big { background: var(--accent-blue-600, #2563eb); border-color: transparent; color: #fff; }
.perm2__stat--big b { color: #fff; }

.perm2__layout { padding: 0 var(--space-5) var(--space-10); }
.perm2__search { display: flex; align-items: center; gap: var(--space-2); padding: 0 var(--space-3); background: var(--bg-muted, rgba(255,255,255,.04)); border: 1px solid var(--border); border-radius: var(--radius-lg); margin-bottom: var(--space-3); }
.perm2__search .icon { color: var(--text-secondary); flex-shrink: 0; }
.perm2__search input { flex: 1 1 auto; background: none; border: none; outline: none; color: var(--text); font-size: var(--text-base); padding: var(--space-3) 0; min-width: 0; }
.perm2__results { display: flex; flex-direction: column; gap: var(--space-2); }
.perm2__item { display: flex; align-items: center; gap: var(--space-3); width: 100%; text-align: left; padding: var(--space-3); background: var(--bg-muted, rgba(255,255,255,.03)); border: 1px solid var(--border); border-radius: var(--radius-lg); cursor: pointer; color: inherit; }
.perm2__item:hover { border-color: var(--accent-blue-600, #2563eb); }
.perm2__item.is-active { border-color: var(--accent-blue-600, #2563eb); box-shadow: 0 0 0 1px var(--accent-blue-600, #2563eb) inset; }
.perm2__item-id { min-width: 0; flex: 1 1 auto; display: flex; flex-direction: column; }
.perm2__item-nome { font-weight: var(--fw-semibold); color: var(--text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.perm2__item-sub { font-size: var(--text-xs); color: var(--text-secondary); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.perm2__item-meta { flex-shrink: 0; display: flex; flex-direction: column; align-items: flex-end; gap: 2px; }
.perm2__cargo-pill { font-size: var(--text-xs); font-weight: var(--fw-medium); color: var(--accent-blue-600, #60a5fa); }
.perm2__count { font-size: var(--text-xs); color: var(--text-secondary); }

.perm2__detail { margin-top: var(--space-4); }
.perm2__empty { display: flex; flex-direction: column; align-items: center; gap: var(--space-3); text-align: center; color: var(--text-secondary); padding: var(--space-10) var(--space-4); border: 1px dashed var(--border); border-radius: var(--radius-2xl, 18px); }
.perm2__empty .icon-lg { opacity: .4; }
.perm2__back { display: inline-flex; align-items: center; gap: var(--space-1); background: none; border: none; color: var(--accent-blue-600, #60a5fa); font-weight: var(--fw-medium); cursor: pointer; padding: var(--space-2) 0; margin-bottom: var(--space-2); }
.perm2__dhead { display: flex; align-items: center; gap: var(--space-3); padding-bottom: var(--space-3); border-bottom: 1px solid var(--border); margin-bottom: var(--space-4); }
.team-row__av--lg { width: 52px; height: 52px; font-size: var(--text-lg); }
.perm2__dnome { display: block; font-weight: var(--fw-bold); font-size: var(--text-lg); color: var(--text); }
.perm2__dsub { display: block; font-size: var(--text-xs); color: var(--text-secondary); }
.perm2__cargos-head { display: flex; align-items: center; justify-content: space-between; gap: var(--space-2); }
.perm2__gtit { font-size: var(--text-xs); text-transform: uppercase; letter-spacing: .1em; color: var(--text-secondary); margin: 0 0 var(--space-2); }
.perm2__rename { display: inline-flex; align-items: center; gap: 4px; background: none; border: none; color: var(--text-secondary); font-size: var(--text-xs); cursor: pointer; padding: var(--space-1) var(--space-2); border-radius: var(--radius-md); }
.perm2__rename:hover { color: var(--text); background: var(--bg-muted); }
.perm2__cargos { display: flex; flex-wrap: wrap; gap: var(--space-2); margin-bottom: var(--space-5); }
.perm2__cargo { display: inline-flex; align-items: center; gap: 6px; padding: var(--space-2) var(--space-4); border: 1px solid var(--border); border-radius: 999px; background: var(--bg-muted, rgba(255,255,255,.03)); color: var(--text); font-weight: var(--fw-medium); cursor: pointer; }
.perm2__cargo:hover { border-color: var(--accent-blue-600, #2563eb); }
.perm2__cargo.is-on { background: var(--accent-blue-600, #2563eb); border-color: transparent; color: #fff; }

/* Preset = chip aplicável + botão excluir colado (Permissões 2.0) */
.perm2__preset { display: inline-flex; align-items: stretch; }
.perm2__preset .perm2__cargo { border-top-right-radius: 0; border-bottom-right-radius: 0; }
.perm2__preset.is-on .perm2__cargo { background: var(--accent-blue-600, #2563eb); border-color: transparent; color: #fff; }
.perm2__preset-del { display: inline-flex; align-items: center; justify-content: center; width: 34px; border: 1px solid var(--border); border-left: none; border-radius: 0 999px 999px 0; background: var(--bg-muted, rgba(255,255,255,.03)); color: var(--text-secondary); cursor: pointer; }
.perm2__preset-del:hover { color: var(--danger); background: var(--danger-bg); }
.perm2__nopreset { font-size: var(--text-sm); color: var(--text-secondary); }
.perm2__savepreset { margin-top: var(--space-4); }
.perm2__fine { background: var(--bg-muted, rgba(255,255,255,.03)); border: 1px solid var(--border); border-radius: var(--radius-2xl, 18px); padding: var(--space-4); }
.perm2__grupo + .perm2__grupo { margin-top: var(--space-4); }
.perm2__glbl { display: block; font-size: var(--text-xs); text-transform: uppercase; letter-spacing: .08em; color: var(--text-secondary); margin-bottom: var(--space-1); }

/* Mobile: ao escolher um servidor, mostra só a edição (lista fica acessível pelo "← Lista"). */
.perm2__back { display: inline-flex; }
.perm2--open .perm2__list { display: none; }
@media (min-width: 900px) {
  .perm2__layout { display: grid; grid-template-columns: 340px 1fr; gap: var(--space-6); align-items: start; }
  .perm2__list { position: sticky; top: var(--space-4); }
  .perm2__results { max-height: 60vh; overflow-y: auto; padding-right: 2px; }
  .perm2__detail { margin-top: 0; }
  .perm2__back { display: none; }          /* no desktop os dois painéis convivem */
  .perm2--open .perm2__list { display: block; }
}

/* ===== Cupom da senha (impressão) ============================================
   Fica no DOM mas escondido na tela; @media print revela só ele e oculta o app,
   p/ sair só o ticket do cidadão (serve em impressora comum ou térmica). */
.senha-cupom { display: none; }

@media print {
  body * { visibility: hidden !important; }
  #senha-cupom, #senha-cupom * { visibility: visible !important; }
  #senha-cupom {
    display: block !important;
    position: fixed; left: 0; top: 0; width: 100%;
    padding: 8mm 4mm; margin: 0;
    text-align: center; color: #000; background: #fff;
    font-family: Geist, system-ui, sans-serif;
  }
  .senha-cupom__head { font-size: 14pt; font-weight: 700; }
  .senha-cupom__sub { font-size: 8pt; margin-top: 1mm; }
  .senha-cupom__rule { border-top: 1px dashed #000; margin: 4mm 0; }
  .senha-cupom__lbl { font-size: 10pt; text-transform: uppercase; letter-spacing: .1em; }
  .senha-cupom__num { font-size: 56pt; font-weight: 800; line-height: 1; margin: 2mm 0; }
  .senha-cupom__prio { font-size: 12pt; font-weight: 700; }
  .senha-cupom__serv { font-size: 12pt; }
  .senha-cupom__time { font-size: 9pt; }
  .senha-cupom__foot { font-size: 9pt; margin-top: 3mm; }
  @page { margin: 0; }
}

/* ===== Sininho de notificações (dash-hero) ================================== */
.dash-hero__tools { display: flex; align-items: center; gap: var(--space-2); flex-shrink: 0; }
.bell { position: relative; }
.bell__btn { display: inline-flex; align-items: center; justify-content: center; width: 40px; height: 40px;
  border-radius: 50%; border: 1px solid var(--border); background: rgba(255,255,255,.06); color: var(--text);
  cursor: pointer; -webkit-appearance: none; appearance: none; position: relative; }
.bell__btn:hover { background: rgba(255,255,255,.12); }
.bell__badge { position: absolute; top: -3px; right: -3px; min-width: 18px; height: 18px; padding: 0 4px;
  display: inline-flex; align-items: center; justify-content: center; border-radius: 999px;
  background: var(--danger, #e5484d); color: #fff; font-size: 10px; font-weight: 700; line-height: 1;
  border: 2px solid var(--primary-900, #0b1f3a); }

/* Lista de avisos dentro do Modal */
.notif-feed { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 2px;
  max-height: 60vh; overflow-y: auto; }
.notif-feed__item { display: flex; align-items: flex-start; gap: var(--space-3); padding: var(--space-3);
  border-radius: var(--radius-md, 10px); }
.notif-feed__item:hover { background: var(--surface-2, rgba(0,0,0,.03)); }
.notif-feed__ic { flex-shrink: 0; width: 34px; height: 34px; border-radius: 50%; display: inline-flex;
  align-items: center; justify-content: center; background: var(--primary-50, #eef3fb); color: var(--primary); }
.notif-feed__ic--atendimento_concluido { background: var(--success-50, #e7f6ed); color: var(--success, #2e7d32); }
.notif-feed__body { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.notif-feed__msg { font-size: var(--text-sm); color: var(--text); font-weight: 600; }
.notif-feed__time { font-size: var(--text-xs); color: var(--text-secondary); }
.notif-feed__empty { text-align: center; padding: var(--space-6) 0; color: var(--text-secondary); }
.notif-feed__empty .icon-lg { color: var(--text-tertiary, #9aa4b2); margin-bottom: var(--space-2); }

/* Opção de aviso na Central (rótulo com sub) */
.notif-opt { display: inline-flex; align-items: center; gap: 6px; font-weight: 600; }
.notif-opt__sub { display: block; font-size: var(--text-xs); color: var(--text-secondary); font-weight: 400; margin-top: 2px; }

/* Botão silenciar (topo do modal de notificações) */
.notif-mute { display: flex; align-items: center; gap: 8px; width: 100%; margin-bottom: var(--space-3);
  padding: 10px 12px; border-radius: var(--radius-md, 10px); border: 1px solid var(--border);
  background: var(--success-50, #e7f6ed); color: var(--success, #2e7d32); font: inherit; font-size: var(--text-sm);
  font-weight: 600; cursor: pointer; -webkit-appearance: none; appearance: none; text-align: left; }
.notif-mute.is-muted { background: var(--surface-2, #f1f3f5); color: var(--text-secondary); }
.notif-mute:hover { filter: brightness(.97); }

/* Botão "Escolher voz" na tela inicial do Monitor (fundo escuro) */
#mon-voz { border: 1px solid rgba(255,255,255,.35); background: rgba(255,255,255,.06); color: #fff; }
#mon-voz:hover { background: rgba(255,255,255,.14); }

/* Bloco "Voz da chamada (gravada)" no seletor */
.voz-call { display: flex; align-items: center; gap: var(--space-3); padding: var(--space-3);
  border-radius: var(--radius-md, 10px); background: var(--primary-50, #eef3fb); border: 1px solid var(--border); }
.voz-call__txt { display: flex; flex-direction: column; gap: 2px; min-width: 0; flex: 1; }
.voz-call__txt strong { font-size: var(--text-sm); color: var(--text); }
.voz-call__txt span { font-size: var(--text-xs); color: var(--text-secondary); }
.voz-call .btn { flex-shrink: 0; }
