/* =========================================================
   SinalBase — folha de estilos principal
   Order: 1) tokens  2) reset  3) layout  4) sidebar/topbar
   5) cards/panels  6) buttons  7) forms  8) tables
   9) badges/status 10) dashboards 11) pages 12) responsive
   ========================================================= */

/* 1. TOKENS ----------------------------------------------- */
:root {
  /* surfaces (dark institucional) */
  --gf-bg-0: #08090f;
  --gf-bg-1: #0d111c;
  --gf-bg-2: #131829;
  --gf-bg-3: #1a2138;
  --gf-bg-hover: #1f2740;
  --gf-border: rgba(255,255,255,.07);
  --gf-border-strong: rgba(255,255,255,.12);
  --gf-divider: rgba(255,255,255,.05);

  /* text */
  --gf-text-1: #eef1f8;
  --gf-text-2: #a0a8bf;
  --gf-text-3: #6a7290;
  --gf-text-4: #4a5170;

  /* accent (institutional blue — matches logo) */
  --gf-accent: #2c7cff;
  --gf-accent-soft: rgba(44,124,255,.14);
  --gf-accent-line: rgba(44,124,255,.28);
  --gf-accent-2: #00b8ff;

  /* status hues */
  --gf-slate: #94a3b8;     --gf-slate-bg: rgba(148,163,184,.12);
  --gf-amber: #f59e0b;     --gf-amber-bg: rgba(245,158,11,.13);
  --gf-cyan: #22d3ee;      --gf-cyan-bg: rgba(34,211,238,.12);
  --gf-violet: #a78bfa;    --gf-violet-bg: rgba(167,139,250,.13);
  --gf-indigo: #818cf8;    --gf-indigo-bg: rgba(129,140,248,.13);
  --gf-yellow: #facc15;    --gf-yellow-bg: rgba(250,204,21,.13);
  --gf-emerald: #34d399;   --gf-emerald-bg: rgba(52,211,153,.13);
  --gf-rose: #fb7185;      --gf-rose-bg: rgba(251,113,133,.13);
  --gf-red: #ef4444;       --gf-red-bg: rgba(239,68,68,.13);

  /* spacing */
  --gf-r-xs: 4px;
  --gf-r-sm: 6px;
  --gf-r-md: 8px;
  --gf-r-lg: 10px;
  --gf-r-xl: 14px;

  /* layout */
  --gf-sidebar-w: 244px;
  --gf-topbar-h: 56px;

  /* type */
  --gf-font: "Manrope", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --gf-mono: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;
}

/* 2. RESET ------------------------------------------------ */
*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; height: 100%; }
body {
  font-family: var(--gf-font);
  background: var(--gf-bg-0);
  color: var(--gf-text-1);
  font-size: 14px;
  line-height: 1.45;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  letter-spacing: -0.005em;
}
a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; }
input, textarea, select { font-family: inherit; }
img { display: block; max-width: 100%; }
hr { border: 0; border-top: 1px solid var(--gf-divider); margin: 14px 0; }

::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: #232a45; border-radius: 8px; border: 2px solid var(--gf-bg-0); }
::-webkit-scrollbar-thumb:hover { background: #2e3756; }

/* 3. LAYOUT ----------------------------------------------- */
.gf-app {
  display: grid;
  grid-template-columns: var(--gf-sidebar-w) 1fr;
  min-height: 100vh;
}
.gf-main {
  display: grid;
  grid-template-rows: var(--gf-topbar-h) 1fr;
  min-width: 0;
  min-height: 100vh;
}
.gf-content {
  padding: 22px 28px 64px;
  overflow-y: auto;
  min-height: 0;
}
.gf-page-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 20px;
  flex-wrap: wrap;
}
.gf-page-title { font-size: 22px; font-weight: 700; letter-spacing: -0.018em; margin: 0; }
.gf-page-sub { color: var(--gf-text-2); font-size: 13px; margin-top: 4px; }
.gf-page-actions { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }

/* 4. SIDEBAR / TOPBAR ------------------------------------ */
.gf-sidebar {
  background: var(--gf-bg-1);
  border-right: 1px solid var(--gf-border);
  display: flex;
  flex-direction: column;
  padding: 14px 12px 16px;
  position: sticky;
  top: 0;
  height: 100vh;
}
.gf-sidebar__logo {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 4px 8px 18px;
  border-bottom: 1px solid var(--gf-divider);
  margin-bottom: 12px;
}
.gf-sidebar__logo img { height: 30px; width: auto; }
.gf-sidebar__nav { display: flex; flex-direction: column; gap: 1px; min-height: 0; overflow-y: auto; flex: 1; }
.gf-nav-group { font-size: 10.5px; text-transform: uppercase; letter-spacing: .08em; color: var(--gf-text-4); padding: 14px 10px 6px; font-weight: 700; }
.gf-nav-item {
  display: flex;
  align-items: center;
  gap: 11px;
  padding: 8px 10px;
  border-radius: var(--gf-r-md);
  color: var(--gf-text-2);
  font-weight: 500;
  font-size: 13.5px;
  cursor: pointer;
  border: 1px solid transparent;
  transition: background .12s, color .12s;
  position: relative;
}
.gf-nav-item:hover { background: var(--gf-bg-2); color: var(--gf-text-1); }
.gf-nav-item.is-active {
  background: var(--gf-accent-soft);
  color: var(--gf-text-1);
  border-color: var(--gf-accent-line);
}
.gf-nav-item.is-active .gf-nav-ico { color: var(--gf-accent); }
.gf-nav-ico { width: 18px; height: 18px; display: inline-flex; align-items: center; justify-content: center; color: var(--gf-text-3); }
.gf-nav-item:hover .gf-nav-ico { color: var(--gf-text-1); }
.gf-nav-badge {
  margin-left: auto;
  font-size: 10.5px;
  font-weight: 700;
  background: var(--gf-bg-3);
  color: var(--gf-text-1);
  border-radius: 999px;
  padding: 1px 7px;
  min-width: 20px;
  text-align: center;
}
.gf-nav-badge.is-danger { background: var(--gf-red); color: white; }
.gf-nav-badge.is-warn { background: var(--gf-amber); color: #1a1305; }

.gf-sidebar__foot {
  border-top: 1px solid var(--gf-divider);
  padding-top: 10px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.gf-user-chip {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 10px;
  border-radius: var(--gf-r-md);
  cursor: pointer;
}
.gf-user-chip:hover { background: var(--gf-bg-2); }
.gf-user-chip__name { font-size: 13px; font-weight: 600; }
.gf-user-chip__role { font-size: 11px; color: var(--gf-text-3); display: flex; align-items: center; gap: 5px; }
.gf-user-chip__role::before { content: ""; width: 6px; height: 6px; border-radius: 99px; background: var(--gf-emerald); display: inline-block; }

.gf-topbar {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 0 22px 0 28px;
  background: var(--gf-bg-1);
  border-bottom: 1px solid var(--gf-border);
  height: var(--gf-topbar-h);
  position: sticky; top: 0; z-index: 20;
}
.gf-crumbs { display: flex; align-items: center; gap: 7px; color: var(--gf-text-3); font-size: 13px; }
.gf-crumbs__sep { color: var(--gf-text-4); }
.gf-crumbs__current { color: var(--gf-text-1); font-weight: 600; }
.gf-topbar__search {
  margin-left: auto;
  display: flex; align-items: center; gap: 8px;
  background: var(--gf-bg-2);
  border: 1px solid var(--gf-border);
  border-radius: var(--gf-r-md);
  padding: 6px 10px;
  width: 380px;
  color: var(--gf-text-3);
  font-size: 13px;
}
.gf-topbar__search input { background: transparent; border: 0; outline: none; color: var(--gf-text-1); flex: 1; font-size: 13px; }
.gf-topbar__search kbd { font-family: var(--gf-mono); font-size: 10.5px; color: var(--gf-text-3); border: 1px solid var(--gf-border); padding: 1px 5px; border-radius: 4px; }
.gf-icon-btn {
  width: 34px; height: 34px;
  display: inline-flex; align-items: center; justify-content: center;
  border-radius: var(--gf-r-md);
  background: transparent;
  border: 1px solid transparent;
  color: var(--gf-text-2);
  position: relative;
}
.gf-icon-btn:hover { background: var(--gf-bg-2); color: var(--gf-text-1); }
.gf-icon-btn .gf-pill {
  position: absolute; top: 3px; right: 3px;
  min-width: 16px; height: 16px; padding: 0 4px;
  background: var(--gf-red); color: white;
  border-radius: 99px;
  font-size: 10px; font-weight: 700;
  display: inline-flex; align-items: center; justify-content: center;
  border: 2px solid var(--gf-bg-1);
}

/* 5. CARDS / PANELS -------------------------------------- */
.gf-panel {
  background: var(--gf-bg-1);
  border: 1px solid var(--gf-border);
  border-radius: var(--gf-r-lg);
  overflow: hidden;
}
.gf-panel__head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 13px 16px;
  border-bottom: 1px solid var(--gf-divider);
  gap: 10px;
}
.gf-panel__title { font-size: 13.5px; font-weight: 700; letter-spacing: -0.005em; }
.gf-panel__sub { font-size: 12px; color: var(--gf-text-3); font-weight: 500; }
.gf-panel__body { padding: 14px 16px; }
.gf-panel__body--flush { padding: 0; }
.gf-panel__foot {
  padding: 10px 16px;
  border-top: 1px solid var(--gf-divider);
  font-size: 12px;
  color: var(--gf-text-3);
  display: flex; align-items: center; justify-content: space-between;
}

.gf-card {
  background: var(--gf-bg-1);
  border: 1px solid var(--gf-border);
  border-radius: var(--gf-r-lg);
  padding: 14px 16px;
}

.gf-kpi {
  background: var(--gf-bg-1);
  border: 1px solid var(--gf-border);
  border-radius: var(--gf-r-lg);
  padding: 14px 16px 16px;
  display: flex; flex-direction: column; gap: 4px;
  position: relative;
  min-height: 116px;
  cursor: pointer;
  transition: border-color .14s, transform .14s;
}
.gf-kpi:hover { border-color: var(--gf-border-strong); transform: translateY(-1px); }
.gf-kpi__head { display: flex; align-items: center; gap: 10px; }
.gf-kpi__ico {
  width: 30px; height: 30px;
  display: inline-flex; align-items: center; justify-content: center;
  border-radius: var(--gf-r-md);
  background: var(--gf-bg-3);
  color: var(--gf-text-2);
}
.gf-kpi__label { font-size: 12.5px; color: var(--gf-text-2); font-weight: 500; }
.gf-kpi__value { font-size: 30px; font-weight: 700; letter-spacing: -0.02em; line-height: 1.05; margin-top: 6px; font-feature-settings: "tnum"; }
.gf-kpi__delta { font-size: 11.5px; color: var(--gf-text-3); margin-top: 6px; display: flex; align-items: center; gap: 5px; }
.gf-kpi__delta.is-up { color: var(--gf-emerald); }
.gf-kpi__delta.is-down { color: var(--gf-rose); }
.gf-kpi--accent .gf-kpi__ico { background: var(--gf-accent-soft); color: var(--gf-accent); }
.gf-kpi--warn .gf-kpi__ico { background: var(--gf-amber-bg); color: var(--gf-amber); }
.gf-kpi--danger .gf-kpi__ico { background: var(--gf-red-bg); color: var(--gf-red); }
.gf-kpi--ok .gf-kpi__ico { background: var(--gf-emerald-bg); color: var(--gf-emerald); }
.gf-kpi--violet .gf-kpi__ico { background: var(--gf-violet-bg); color: var(--gf-violet); }
.gf-kpi--cyan .gf-kpi__ico { background: var(--gf-cyan-bg); color: var(--gf-cyan); }

/* 6. BUTTONS --------------------------------------------- */
.gf-btn {
  display: inline-flex; align-items: center; gap: 7px;
  background: var(--gf-bg-2);
  color: var(--gf-text-1);
  border: 1px solid var(--gf-border-strong);
  border-radius: var(--gf-r-md);
  padding: 7px 12px;
  font-size: 13px; font-weight: 600;
  transition: background .12s;
}
.gf-btn:hover { background: var(--gf-bg-3); }
.gf-btn--primary { background: var(--gf-accent); border-color: var(--gf-accent); color: white; }
.gf-btn--primary:hover { background: #1b6cee; }
.gf-btn--ghost { background: transparent; border-color: transparent; color: var(--gf-text-2); }
.gf-btn--ghost:hover { background: var(--gf-bg-2); color: var(--gf-text-1); }
.gf-btn--danger { background: var(--gf-red-bg); color: var(--gf-red); border-color: rgba(239,68,68,.3); }
.gf-btn--danger:hover { background: rgba(239,68,68,.2); }
.gf-btn--sm { padding: 4px 9px; font-size: 12px; }
.gf-btn[disabled] { opacity: .45; cursor: not-allowed; }

.gf-tabs { display: flex; gap: 4px; border-bottom: 1px solid var(--gf-divider); margin-bottom: 18px; }
.gf-tab {
  padding: 8px 14px;
  background: transparent; border: 0;
  color: var(--gf-text-2);
  font-size: 13px; font-weight: 600;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
}
.gf-tab:hover { color: var(--gf-text-1); }
.gf-tab.is-active { color: var(--gf-text-1); border-bottom-color: var(--gf-accent); }

.gf-chip {
  display: inline-flex; align-items: center; gap: 5px;
  font-size: 11.5px; font-weight: 600;
  padding: 3px 9px;
  background: var(--gf-bg-3);
  color: var(--gf-text-2);
  border-radius: 99px;
}
.gf-chip--accent { background: var(--gf-accent-soft); color: var(--gf-accent); }

/* 7. FORMS ----------------------------------------------- */
.gf-input, .gf-select, .gf-textarea {
  width: 100%;
  background: var(--gf-bg-2);
  border: 1px solid var(--gf-border-strong);
  color: var(--gf-text-1);
  border-radius: var(--gf-r-md);
  padding: 8px 10px;
  font-size: 13px;
  outline: none;
}
.gf-input:focus, .gf-select:focus, .gf-textarea:focus { border-color: var(--gf-accent); box-shadow: 0 0 0 3px var(--gf-accent-soft); }
.gf-textarea { min-height: 90px; resize: vertical; }
.gf-label { font-size: 12px; color: var(--gf-text-2); font-weight: 600; margin-bottom: 6px; display: block; }
.gf-field { margin-bottom: 12px; }

/* 8. TABLES ---------------------------------------------- */
.gf-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.gf-table thead th {
  text-align: left;
  font-weight: 600;
  font-size: 11.5px;
  text-transform: uppercase;
  letter-spacing: .04em;
  color: var(--gf-text-3);
  padding: 10px 14px;
  border-bottom: 1px solid var(--gf-divider);
  background: var(--gf-bg-1);
  position: sticky; top: 0;
}
.gf-table tbody td {
  padding: 11px 14px;
  border-bottom: 1px solid var(--gf-divider);
  color: var(--gf-text-1);
  vertical-align: middle;
}
.gf-table tbody tr:hover td { background: var(--gf-bg-2); }
.gf-table tbody tr:last-child td { border-bottom: 0; }
.gf-table td.mono, .gf-table td .mono { font-family: var(--gf-mono); font-size: 12px; color: var(--gf-text-2); }

/* 9. BADGES / STATUS ------------------------------------- */
.gf-badge {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 11.5px; font-weight: 600;
  padding: 3px 9px;
  border-radius: 99px;
  background: var(--gf-slate-bg);
  color: var(--gf-slate);
  line-height: 1.2;
}
.gf-badge::before { content: ""; width: 6px; height: 6px; border-radius: 99px; background: currentColor; }
.gf-badge--prep { background: var(--gf-slate-bg); color: var(--gf-slate); }
.gf-badge--rec  { background: var(--gf-amber-bg); color: var(--gf-amber); }
.gf-badge--done { background: var(--gf-cyan-bg); color: var(--gf-cyan); }
.gf-badge--edit { background: var(--gf-violet-bg); color: var(--gf-violet); }
.gf-badge--edited { background: var(--gf-indigo-bg); color: var(--gf-indigo); }
.gf-badge--review { background: var(--gf-yellow-bg); color: var(--gf-yellow); }
.gf-badge--approved { background: var(--gf-emerald-bg); color: var(--gf-emerald); }
.gf-badge--pend { background: var(--gf-rose-bg); color: var(--gf-rose); }
.gf-badge--bottleneck { background: var(--gf-red-bg); color: var(--gf-red); }
.gf-badge--neutral { background: var(--gf-bg-3); color: var(--gf-text-2); }
.gf-badge--no-dot::before { display: none; }

.gf-avatar {
  width: 30px; height: 30px;
  border-radius: 99px;
  background: linear-gradient(135deg, #2c7cff, #5e3bff);
  color: white;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 11.5px; font-weight: 700;
  flex-shrink: 0;
  letter-spacing: .02em;
}
.gf-avatar--sm { width: 24px; height: 24px; font-size: 10px; }
.gf-avatar--lg { width: 40px; height: 40px; font-size: 13px; }
.gf-avatar-stack { display: inline-flex; }
.gf-avatar-stack .gf-avatar { border: 2px solid var(--gf-bg-1); }
.gf-avatar-stack .gf-avatar + .gf-avatar { margin-left: -8px; }

/* 10. DASHBOARDS ----------------------------------------- */
.gf-grid { display: grid; gap: 14px; }
.gf-grid--cols-2 { grid-template-columns: repeat(2, 1fr); }
.gf-grid--cols-3 { grid-template-columns: repeat(3, 1fr); }
.gf-grid--cols-4 { grid-template-columns: repeat(4, 1fr); }
.gf-grid--cols-12 { grid-template-columns: repeat(12, 1fr); }
.gf-col-3 { grid-column: span 3; }
.gf-col-4 { grid-column: span 4; }
.gf-col-5 { grid-column: span 5; }
.gf-col-6 { grid-column: span 6; }
.gf-col-7 { grid-column: span 7; }
.gf-col-8 { grid-column: span 8; }
.gf-col-9 { grid-column: span 9; }
.gf-col-12 { grid-column: span 12; }

.gf-hero {
  background: linear-gradient(135deg, rgba(44,124,255,.08) 0%, rgba(44,124,255,0) 60%), var(--gf-bg-1);
  border: 1px solid var(--gf-border);
  border-radius: var(--gf-r-lg);
  padding: 20px 24px;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 24px;
  align-items: center;
  margin-bottom: 18px;
}
.gf-hero__greet { font-size: 22px; font-weight: 700; letter-spacing: -0.02em; }
.gf-hero__sub { color: var(--gf-text-2); font-size: 13px; margin-top: 4px; }
.gf-hero__verse {
  border-left: 2px solid var(--gf-accent);
  padding-left: 14px;
  max-width: 420px;
  text-align: left;
}
.gf-hero__verse-text { font-size: 13px; color: var(--gf-text-1); font-style: italic; line-height: 1.5; }
.gf-hero__verse-ref { font-size: 11.5px; color: var(--gf-text-3); font-family: var(--gf-mono); margin-top: 4px; letter-spacing: 0; }

/* health score */
.gf-health {
  display: flex; flex-direction: column; align-items: center; gap: 12px;
  padding: 18px 16px;
}
.gf-health__ring {
  --p: 84;
  --s: 152px;
  width: var(--s); height: var(--s);
  border-radius: 999px;
  background:
    conic-gradient(var(--gf-emerald) calc(var(--p)*1%), var(--gf-bg-3) 0);
  display: grid; place-items: center;
  position: relative;
}
.gf-health__ring::before {
  content: "";
  position: absolute; inset: 10px;
  background: var(--gf-bg-1);
  border-radius: 99px;
}
.gf-health__num { position: relative; font-size: 40px; font-weight: 800; letter-spacing: -0.03em; font-feature-settings: "tnum"; }
.gf-health__label { font-size: 11.5px; color: var(--gf-text-3); text-transform: uppercase; letter-spacing: .06em; font-weight: 700; }

/* timeline */
.gf-timeline { display: flex; flex-direction: column; }
.gf-tl-item {
  display: grid;
  grid-template-columns: 64px 22px 1fr;
  gap: 8px;
  padding: 11px 0;
  border-bottom: 1px solid var(--gf-divider);
  position: relative;
}
.gf-tl-item:last-child { border-bottom: 0; }
.gf-tl-time { font-family: var(--gf-mono); font-size: 11.5px; color: var(--gf-text-3); padding-top: 1px; }
.gf-tl-dot {
  width: 22px; display: flex; justify-content: center;
  position: relative;
}
.gf-tl-dot::before {
  content: ""; width: 8px; height: 8px; border-radius: 99px;
  background: var(--gf-text-4);
  margin-top: 5px;
  box-shadow: 0 0 0 3px var(--gf-bg-1);
}
.gf-tl-dot--accent::before { background: var(--gf-accent); }
.gf-tl-dot--ok::before { background: var(--gf-emerald); }
.gf-tl-dot--warn::before { background: var(--gf-amber); }
.gf-tl-dot--danger::before { background: var(--gf-red); }
.gf-tl-body { font-size: 13px; }
.gf-tl-body strong { font-weight: 600; }
.gf-tl-meta { color: var(--gf-text-3); font-size: 11.5px; margin-top: 2px; }

/* sector bar list */
.gf-bar-row {
  display: grid;
  grid-template-columns: 150px 1fr 60px 40px;
  gap: 10px;
  align-items: center;
  padding: 9px 0;
  font-size: 13px;
}
.gf-bar-track { height: 8px; background: var(--gf-bg-3); border-radius: 99px; overflow: hidden; }
.gf-bar-fill { height: 100%; background: var(--gf-accent); border-radius: 99px; }
.gf-bar-fill.is-warn { background: var(--gf-amber); }
.gf-bar-fill.is-danger { background: var(--gf-red); }
.gf-bar-fill.is-ok { background: var(--gf-emerald); }
.gf-bar-val { font-family: var(--gf-mono); font-size: 12px; color: var(--gf-text-2); text-align: right; }
.gf-bar-trend { font-size: 11px; text-align: right; }
.gf-bar-trend.is-up { color: var(--gf-emerald); }
.gf-bar-trend.is-down { color: var(--gf-rose); }

/* 11. PAGES ---------------------------------------------- */

/* production list card */
.gf-prod-row {
  display: grid;
  grid-template-columns: 56px 1fr 200px 180px 180px 120px;
  gap: 14px;
  align-items: center;
  padding: 12px 14px;
  border-bottom: 1px solid var(--gf-divider);
  font-size: 13px;
  cursor: pointer;
  transition: background .12s;
}
.gf-prod-row:hover { background: var(--gf-bg-2); }
.gf-prod-row__pgm {
  font-family: var(--gf-mono);
  font-size: 13.5px;
  font-weight: 700;
  color: var(--gf-text-1);
  background: var(--gf-bg-3);
  border-radius: var(--gf-r-sm);
  padding: 6px 0;
  text-align: center;
}
.gf-prod-row__title { font-weight: 600; }
.gf-prod-row__theme { color: var(--gf-text-3); font-size: 12px; margin-top: 2px; }

/* flow strip (mini stepper) */
.gf-flow-strip {
  display: flex;
  align-items: center;
  gap: 0;
  font-size: 11px;
  color: var(--gf-text-3);
  flex-wrap: nowrap;
}
.gf-flow-step {
  flex: 1;
  display: flex; align-items: center; gap: 4px;
  position: relative;
}
.gf-flow-step__dot {
  width: 10px; height: 10px; border-radius: 99px;
  background: var(--gf-bg-3);
  border: 2px solid var(--gf-bg-1);
  flex-shrink: 0;
}
.gf-flow-step.is-done .gf-flow-step__dot { background: var(--gf-emerald); }
.gf-flow-step.is-active .gf-flow-step__dot { background: var(--gf-accent); box-shadow: 0 0 0 3px var(--gf-accent-soft); }
.gf-flow-step.is-blocked .gf-flow-step__dot { background: var(--gf-red); }
.gf-flow-step__line {
  flex: 1; height: 2px; background: var(--gf-bg-3); margin: 0 4px;
}
.gf-flow-step.is-done + .gf-flow-step .gf-flow-step__line,
.gf-flow-step.is-done .gf-flow-step__line { background: var(--gf-emerald); }

/* kanban */
.gf-kanban { display: grid; grid-template-columns: repeat(7, minmax(220px, 1fr)); gap: 12px; overflow-x: auto; padding-bottom: 10px; }
.gf-kanban__col { background: var(--gf-bg-1); border: 1px solid var(--gf-border); border-radius: var(--gf-r-lg); display: flex; flex-direction: column; min-height: 360px; }
.gf-kanban__col-head {
  padding: 11px 13px;
  border-bottom: 1px solid var(--gf-divider);
  display: flex; align-items: center; justify-content: space-between;
  font-size: 12.5px; font-weight: 700;
}
.gf-kanban__col-body { padding: 8px; display: flex; flex-direction: column; gap: 8px; flex: 1; }
.gf-kcard {
  background: var(--gf-bg-2);
  border: 1px solid var(--gf-border);
  border-radius: var(--gf-r-md);
  padding: 10px 11px;
  font-size: 12.5px;
  cursor: pointer;
  transition: border-color .12s, transform .12s;
}
.gf-kcard:hover { border-color: var(--gf-border-strong); transform: translateY(-1px); }
.gf-kcard__pgm { font-family: var(--gf-mono); font-size: 11px; color: var(--gf-text-3); }
.gf-kcard__title { font-weight: 600; margin: 2px 0 6px; }
.gf-kcard__row { display: flex; align-items: center; justify-content: space-between; font-size: 11px; color: var(--gf-text-3); }
.gf-kcard.is-warn { border-left: 3px solid var(--gf-amber); }
.gf-kcard.is-danger { border-left: 3px solid var(--gf-red); }

/* drawer (detalhe de fluxo) */
.gf-drawer-bg { position: fixed; inset: 0; background: rgba(5,8,15,.6); z-index: 50; opacity: 0; pointer-events: none; transition: opacity .2s; }
.gf-drawer-bg.is-open { opacity: 1; pointer-events: auto; }
.gf-drawer {
  position: fixed; top: 0; right: 0; height: 100vh; width: 560px; max-width: 92vw;
  background: var(--gf-bg-1); border-left: 1px solid var(--gf-border);
  z-index: 60; transform: translateX(100%); transition: transform .26s cubic-bezier(.32,.72,.2,1);
  display: flex; flex-direction: column;
}
.gf-drawer.is-open { transform: translateX(0); }
.gf-drawer__head { padding: 16px 20px; border-bottom: 1px solid var(--gf-divider); display: flex; align-items: center; justify-content: space-between; }
.gf-drawer__body { padding: 18px 20px; overflow-y: auto; flex: 1; }
.gf-drawer__foot { padding: 12px 20px; border-top: 1px solid var(--gf-divider); display: flex; justify-content: space-between; gap: 8px; align-items: center; }

/* notifications dropdown */
.gf-notif-pop {
  position: absolute; top: 44px; right: 14px;
  width: 380px; max-height: 540px;
  background: var(--gf-bg-1); border: 1px solid var(--gf-border-strong);
  border-radius: var(--gf-r-lg);
  z-index: 80;
  display: flex; flex-direction: column;
  box-shadow: 0 18px 56px rgba(0,0,0,.5);
}
.gf-notif-pop__head { padding: 12px 14px; border-bottom: 1px solid var(--gf-divider); display: flex; justify-content: space-between; align-items: center; }
.gf-notif-pop__body { overflow-y: auto; flex: 1; }
.gf-notif-item {
  padding: 11px 14px;
  border-bottom: 1px solid var(--gf-divider);
  cursor: pointer;
  display: flex; gap: 10px;
}
.gf-notif-item:hover { background: var(--gf-bg-2); }
.gf-notif-item.is-unread { background: rgba(44,124,255,.04); }
.gf-notif-item.is-unread::before {
  content: ""; width: 6px; height: 6px; border-radius: 99px;
  background: var(--gf-accent); margin-top: 6px; flex-shrink: 0;
}
.gf-notif-item__title { font-size: 13px; font-weight: 600; }
.gf-notif-item__msg { font-size: 12px; color: var(--gf-text-2); margin-top: 2px; }
.gf-notif-item__time { font-size: 11px; color: var(--gf-text-3); margin-top: 4px; font-family: var(--gf-mono); }

/* alerts banner (avisos) */
.gf-alert {
  border: 1px solid var(--gf-border);
  background: var(--gf-bg-1);
  border-radius: var(--gf-r-lg);
  padding: 12px 14px;
  display: flex; gap: 12px; align-items: flex-start;
  border-left: 3px solid var(--gf-accent);
}
.gf-alert--warn { border-left-color: var(--gf-amber); background: linear-gradient(0deg, rgba(245,158,11,.04), rgba(245,158,11,.04)), var(--gf-bg-1); }
.gf-alert--danger { border-left-color: var(--gf-red); background: linear-gradient(0deg, rgba(239,68,68,.05), rgba(239,68,68,.05)), var(--gf-bg-1); }
.gf-alert__title { font-size: 13.5px; font-weight: 700; }
.gf-alert__msg { font-size: 12.5px; color: var(--gf-text-2); margin-top: 2px; }

/* empty */
.gf-empty {
  padding: 36px 16px;
  text-align: center;
  color: var(--gf-text-3);
  font-size: 13px;
}
.gf-empty__title { color: var(--gf-text-2); font-weight: 600; margin-bottom: 4px; font-size: 13.5px; }

/* public confirmation page */
.gf-public {
  min-height: 100vh;
  display: grid; place-items: center;
  padding: 24px;
  background:
    radial-gradient(circle at 20% 10%, rgba(44,124,255,.10), transparent 40%),
    radial-gradient(circle at 80% 80%, rgba(0,184,255,.06), transparent 40%),
    var(--gf-bg-0);
}
.gf-public__card {
  width: 480px; max-width: 100%;
  background: var(--gf-bg-1);
  border: 1px solid var(--gf-border-strong);
  border-radius: var(--gf-r-xl);
  padding: 28px 28px 24px;
}
.gf-public__logo { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.gf-public__logo img { height: 28px; }

/* login */
.gf-login { min-height: 100vh; display: grid; grid-template-columns: 1fr 1fr; }
.gf-login__aside {
  background:
    radial-gradient(circle at 10% 10%, rgba(44,124,255,.18), transparent 50%),
    radial-gradient(circle at 80% 70%, rgba(0,184,255,.10), transparent 50%),
    var(--gf-bg-1);
  border-right: 1px solid var(--gf-border);
  padding: 56px;
  display: flex; flex-direction: column; justify-content: space-between;
}
.gf-login__main { display: grid; place-items: center; padding: 32px; }
.gf-login__form { width: 360px; max-width: 100%; }
.gf-login__logo img { height: 40px; }

/* footer line */
.gf-footer-line { display: flex; align-items: center; justify-content: space-between; font-size: 12px; color: var(--gf-text-3); margin-top: 22px; padding: 12px 0 0; border-top: 1px solid var(--gf-divider); }

/* misc */
.mono { font-family: var(--gf-mono); }
.text-muted { color: var(--gf-text-3); }
.text-soft { color: var(--gf-text-2); }
.center { text-align: center; }
.right { text-align: right; }
.flex { display: flex; }
.flex-col { display: flex; flex-direction: column; }
.items-center { align-items: center; }
.between { justify-content: space-between; }
.gap-2 { gap: 6px; }
.gap-3 { gap: 10px; }
.gap-4 { gap: 14px; }
.mt-1 { margin-top: 4px; }
.mt-2 { margin-top: 8px; }
.mt-3 { margin-top: 14px; }
.mt-4 { margin-top: 20px; }
.mb-2 { margin-bottom: 8px; }
.mb-3 { margin-bottom: 14px; }
.mb-4 { margin-bottom: 20px; }
.w-full { width: 100%; }
.nowrap { white-space: nowrap; }
.truncate { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* density modes (Tweaks) */
.gf--density-compact { font-size: 13px; }
.gf--density-compact .gf-kpi__value { font-size: 26px; }
.gf--density-compact .gf-kpi { min-height: 100px; padding: 12px 14px 14px; }
.gf--density-compact .gf-content { padding: 18px 22px 56px; }
.gf--density-compact .gf-table tbody td { padding: 8px 12px; }
.gf--density-compact .gf-prod-row { padding: 9px 12px; }

.gf--density-comfortable { font-size: 15px; }
.gf--density-comfortable .gf-kpi__value { font-size: 34px; }
.gf--density-comfortable .gf-kpi { min-height: 128px; padding: 18px 20px 20px; }
.gf--density-comfortable .gf-content { padding: 28px 36px 72px; }

/* 12. RESPONSIVE ---------------------------------------- */
@media (max-width: 1280px) {
  .gf-grid--cols-4 { grid-template-columns: repeat(2, 1fr); }
  .gf-col-3 { grid-column: span 6; }
  .gf-col-4 { grid-column: span 6; }
  .gf-col-8 { grid-column: span 12; }
  .gf-col-9 { grid-column: span 12; }
  .gf-topbar__search { width: 260px; }
}
@media (max-width: 1000px) {
  .gf-app { grid-template-columns: 64px 1fr; }
  .gf-sidebar { padding: 12px 6px; }
  .gf-sidebar__logo span, .gf-nav-item span:not(.gf-nav-badge), .gf-user-chip__name, .gf-user-chip__role, .gf-nav-group { display: none; }
  .gf-sidebar__logo { justify-content: center; }
  .gf-nav-item { justify-content: center; }
}

/* Ajustes operacionais e responsividade */
.gf-prod-head{padding:10px 14px;border-bottom:1px solid var(--gf-divider);display:grid;grid-template-columns:56px 1fr 180px 180px 140px 160px;gap:14px;font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--gf-text-3);font-weight:700}
.gf-prod-row{display:grid;grid-template-columns:56px 1fr 180px 180px 140px 160px;gap:14px;align-items:center;text-decoration:none;color:inherit;padding:14px;border-bottom:1px solid var(--gf-divider)}
.gf-prod-row:hover,.gf-mini-row:hover{background:var(--gf-bg-2)}
.gf-kcard{text-decoration:none;color:inherit;display:block}
.gf-actionbar{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.gf-inline-form{display:flex;gap:6px;align-items:center;flex-wrap:wrap}
.gf-ml-auto{margin-left:auto}
.gf-flow-labels{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;margin-top:8px;font-size:10px;color:var(--gf-text-3);text-align:center}
.gf-responsive-line{display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap}
.gf-user-card{min-height:215px}
.gf-user-link-editor{margin-top:14px}
.gf-user-editor-open{overflow:hidden}
.gf-user-editor-modal[hidden]{display:none!important}
.gf-user-editor-modal{position:fixed!important;inset:0!important;z-index:150!important;align-items:center;justify-content:center;padding:24px;background:rgba(2,8,23,.66);backdrop-filter:blur(3px)}
.gf-user-editor-popover{position:relative;z-index:151;width:min(780px,calc(100vw - 32px));max-height:calc(100vh - 48px);overflow:auto;padding:18px;border:1px solid var(--gf-border);background:linear-gradient(180deg,var(--gf-bg-1),var(--gf-bg-2));border-radius:var(--gf-r-lg);box-shadow:0 28px 90px rgba(0,0,0,.45)}
.gf-user-editor-head{position:sticky;top:-18px;z-index:2;display:flex;justify-content:space-between;align-items:flex-start;gap:16px;padding:0 0 14px;margin-bottom:12px;background:linear-gradient(180deg,var(--gf-bg-1),rgba(15,23,42,.92));border-bottom:1px solid var(--gf-divider)}
.gf-user-editor-actions{position:sticky;bottom:-18px;display:flex;justify-content:flex-end;gap:8px;margin:12px -18px -18px;padding:12px 18px;background:linear-gradient(0deg,var(--gf-bg-2),rgba(15,23,42,.92));border-top:1px solid var(--gf-divider)}
.gf-user-admin-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px;padding-top:12px;border-top:1px solid var(--gf-divider)}
.gf-user-admin-actions form{margin:0}
.gf-editbox{margin-top:12px;padding:12px;border:1px solid var(--gf-border);background:var(--gf-bg-2);border-radius:var(--gf-r-md)}
.gf-editbox--floating{margin-top:0;padding:0;border:0;background:transparent;border-radius:0}
.gf-checkgrid{display:flex;flex-wrap:wrap;gap:8px;padding:10px;background:var(--gf-bg-2);border:1px solid var(--gf-border);border-radius:var(--gf-r-md);max-height:210px;overflow:auto}
.gf-checkgrid .gf-chip{cursor:pointer}
.gf-mini-row{display:grid;grid-template-columns:90px 1fr auto;gap:10px;align-items:center;text-decoration:none;color:inherit;padding:10px 0;border-bottom:1px solid var(--gf-divider)}
.gf-btn[disabled]{opacity:.45;cursor:not-allowed;pointer-events:none}

@media (max-width: 1100px){
  .gf-user-editor-modal{padding:12px!important;align-items:stretch!important}
  .gf-user-editor-popover{width:100%!important;max-height:none!important;height:calc(100vh - 24px)}
  .gf-user-editor-head{top:-18px}

  .gf-app{display:block}
  .gf-sidebar{position:relative;width:auto;min-height:auto;display:block;border-right:0;border-bottom:1px solid var(--gf-border)}
  .gf-sidebar__nav{display:flex;overflow:auto;padding:10px;gap:6px}.gf-nav-group{display:none}.gf-nav-item{white-space:nowrap}.gf-sidebar__foot{display:none}
  .gf-main{margin:0}.gf-topbar{position:sticky;top:0;z-index:20}.gf-topbar__search{display:none}
  .gf-content{padding:16px}.gf-page-head{align-items:flex-start;gap:12px}.gf-page-actions{width:100%;justify-content:flex-start;flex-wrap:wrap}
  .gf-grid--cols-4,.gf-grid--cols-3,.gf-grid--cols-2,.gf-grid--cols-12{grid-template-columns:1fr!important}.gf-col-4,.gf-col-5,.gf-col-7{grid-column:auto!important}
  .gf-prod-head{display:none}.gf-prod-row{grid-template-columns:46px 1fr;gap:10px}.gf-prod-row>div:nth-child(n+3){grid-column:2}.gf-prod-row .right{text-align:left}
  .gf-kanban{grid-template-columns:1fr!important;overflow:visible}.gf-flow-labels{display:none}.gf-mini-row{grid-template-columns:1fr}.gf-table{min-width:760px}.gf-panel__body--flush{overflow:auto}
}

@media (max-width: 640px){
  .gf-hero{grid-template-columns:1fr!important}.gf-kpi__value{font-size:28px}.gf-actionbar,.gf-inline-form{align-items:stretch;width:100%}.gf-inline-form .gf-input{width:100%!important}.gf-ml-auto{margin-left:0}.gf-btn{width:auto}.gf-tabs{overflow:auto;white-space:nowrap}.gf-public__card{width:auto;margin:12px}
}

.gf-help{font-size:11.5px;color:var(--gf-text-3);margin-top:5px;line-height:1.35}

/* Perfil do usuário */
.gf-avatar { overflow: hidden; }
.gf-avatar--photo { background: var(--gf-bg-3)!important; border: 1px solid var(--gf-border); padding: 0; }
.gf-avatar--photo img { width: 100%; height: 100%; object-fit: cover; border-radius: inherit; }
.gf-profile-card .gf-avatar--lg { width: 86px; height: 86px; font-size: 24px; }
.gf-profile-avatar-wrap { display: flex; justify-content: center; margin: 4px 0 12px; }
.gf-profile-name { margin: 0 0 2px; font-size: 18px; letter-spacing: -.02em; }
.gf-topbar a .gf-avatar, .gf-user-chip .gf-avatar { transition: transform .12s, box-shadow .12s; }
.gf-topbar a:hover .gf-avatar, .gf-user-chip:hover .gf-avatar { transform: translateY(-1px); box-shadow: 0 0 0 2px var(--gf-accent-line); }

/* Programa: logo/foto e listas compactas */
.gf-program-logo{display:inline-flex;align-items:center;justify-content:center;border-radius:14px;overflow:hidden;border:1px solid var(--gf-divider);background:rgba(255,255,255,.04);flex:0 0 auto}
.gf-program-logo img{width:100%;height:100%;object-fit:cover;display:block}
.gf-program-logo--color{box-shadow:inset 0 0 0 999px rgba(255,255,255,.08)}
.gf-compact-list{max-height:360px;overflow:auto;border-top:1px solid var(--gf-divider)}
.gf-status-split{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.gf-team-pills{display:flex;gap:6px;flex-wrap:wrap;margin-top:8px}
.gf-team-pill{font-size:11px;border:1px solid var(--gf-divider);border-radius:999px;padding:4px 8px;color:var(--gf-text-2);background:rgba(255,255,255,.04)}

/* Configurações e atualizações administrativas */
.gf-settings-tabs{overflow:auto;white-space:nowrap}
.gf-settings-panel .gf-panel__head{align-items:flex-start}
.gf-row-editor{padding:12px;border:1px solid var(--gf-border);border-radius:var(--gf-r-md);background:rgba(255,255,255,.02);margin-bottom:10px}
.gf-row-editor__foot{display:flex;align-items:center;gap:10px;justify-content:space-between;flex-wrap:wrap;margin-top:8px}
.gf-check{display:inline-flex;align-items:center;gap:7px;color:var(--gf-text-2);font-size:12px;font-weight:600}
.gf-settings-message-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.gf-message-card{border:1px solid var(--gf-border);border-radius:var(--gf-r-lg);background:rgba(255,255,255,.025);padding:14px}
.gf-message-card__title{font-size:14px;font-weight:800;margin-bottom:3px;color:var(--gf-text-1)}
.gf-chip-list{display:flex;gap:6px;flex-wrap:wrap;margin-top:8px}
.gf-settings-switches{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-bottom:16px}
.gf-switch-row{display:flex;align-items:flex-start;gap:10px;padding:12px;border:1px solid var(--gf-border);border-radius:var(--gf-r-md);background:var(--gf-bg-2);color:var(--gf-text-2);font-size:13px;font-weight:600;line-height:1.35}
.gf-switch-row input{margin-top:2px}
.gf-note-list{margin:10px 0 0;padding-left:18px;color:var(--gf-text-2);line-height:1.55;font-size:13px}
.gf-note-list li{margin:4px 0}
@media(max-width:1100px){.gf-settings-message-grid,.gf-settings-switches{grid-template-columns:1fr}}

/* Dashboard inteligente: ações, saúde e atualizações dinâmicas */
.gf-action-line{display:flex;gap:10px;align-items:flex-start;text-decoration:none;color:inherit;padding:10px 0;border-bottom:1px solid var(--gf-divider)}
.gf-action-line:last-child{border-bottom:0}
.gf-action-line:hover{background:rgba(255,255,255,.025);margin-left:-8px;margin-right:-8px;padding-left:8px;padding-right:8px;border-radius:10px}
.gf-action-line>span:last-child{display:flex;flex-direction:column;gap:3px;min-width:0}
.gf-action-line strong{font-size:13px;color:var(--gf-text-1);line-height:1.25}
.gf-action-line small{font-size:11.5px;color:var(--gf-text-3);line-height:1.35}
.gf-mini-kpi-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}
.gf-mini-kpi-grid a{display:flex;flex-direction:column;gap:3px;text-decoration:none;color:inherit;padding:14px;border:1px solid var(--gf-divider);border-radius:var(--gf-r-md);background:var(--gf-bg-2)}
.gf-mini-kpi-grid a:hover{border-color:var(--gf-accent-line);transform:translateY(-1px)}
.gf-mini-kpi-grid span{font-size:26px;font-weight:800;letter-spacing:-.04em;color:var(--gf-text-1);line-height:1}
.gf-mini-kpi-grid small{font-size:11.5px;color:var(--gf-text-3);text-transform:uppercase;letter-spacing:.04em;font-weight:700}
.gf-live-pulse{animation:gfLivePulse .8s ease-out 1}
@keyframes gfLivePulse{0%{box-shadow:0 0 0 0 rgba(44,124,255,.28)}100%{box-shadow:0 0 0 8px rgba(44,124,255,0)}}
@media(max-width:900px){.gf-mini-kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}

/* Busca, relatórios e atualização dinâmica */
.is-hidden{display:none!important}
.gf-search-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.gf-search-item{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:12px 16px;border-bottom:1px solid var(--gf-divider);color:inherit;text-decoration:none}
.gf-search-item:hover{background:var(--gf-bg-2)}
.gf-search-item>div{min-width:0;display:flex;flex-direction:column;gap:3px}
.gf-search-item small{display:block;color:var(--gf-text-3);font-size:11.5px;line-height:1.35}
.gf-health-readout{border:1px solid var(--gf-border);border-radius:var(--gf-r-md);padding:14px;background:var(--gf-bg-2);display:flex;flex-direction:column;gap:5px}
.gf-health-readout strong{font-size:15px;color:var(--gf-text-1)}
.gf-health-readout span{font-size:12.5px;color:var(--gf-text-2);line-height:1.45}
.gf-health-readout.is-good{border-color:rgba(52,211,153,.25);background:rgba(52,211,153,.08)}
.gf-health-readout.is-warn{border-color:rgba(245,158,11,.25);background:rgba(245,158,11,.08)}
.gf-health-readout.is-danger{border-color:rgba(239,68,68,.25);background:rgba(239,68,68,.08)}
/* Alertas guiados: toast clicável e contextual */
.gf-live-toast{position:fixed;right:22px;bottom:22px;z-index:80;width:min(390px,calc(100vw - 32px));padding:0;border-radius:18px;background:rgba(20,27,43,.96);border:1px solid var(--gf-accent-line);box-shadow:0 18px 55px rgba(0,0,0,.42);color:var(--gf-text-1);font-size:13px;opacity:0;transform:translateY(10px);pointer-events:none;transition:opacity .18s,transform .18s;overflow:hidden;backdrop-filter:blur(14px)}
.gf-live-toast.is-visible{opacity:1;transform:translateY(0);pointer-events:auto}
.gf-live-toast__content{display:grid;gap:4px;padding:14px 42px 14px 15px;color:inherit;text-decoration:none}
.gf-live-toast__label{width:max-content;padding:3px 8px;border-radius:999px;background:rgba(255,255,255,.08);color:var(--gf-text-3);font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.08em}
.gf-live-toast__content strong{font-size:13.5px;line-height:1.28;color:var(--gf-text-1)}
.gf-live-toast__content small{font-size:12px;line-height:1.42;color:var(--gf-text-3)}
.gf-live-toast__action{margin-top:5px;color:var(--gf-accent-2);font-size:12px;font-weight:800}
.gf-live-toast__close{position:absolute;top:9px;right:9px;width:24px;height:24px;border:0;border-radius:999px;background:rgba(255,255,255,.07);color:var(--gf-text-2);cursor:pointer;font-size:17px;line-height:1}
.gf-live-toast__close:hover{background:rgba(255,255,255,.13);color:var(--gf-text-1)}
.gf-live-toast--danger{border-color:rgba(239,68,68,.38)}
.gf-live-toast--warn{border-color:rgba(245,158,11,.36)}
.gf-live-toast--info{border-color:rgba(45,212,191,.32)}
.gf-live-toast--danger .gf-live-toast__label{color:#fecaca;background:rgba(239,68,68,.18)}
.gf-live-toast--warn .gf-live-toast__label{color:#fde68a;background:rgba(245,158,11,.18)}
.gf-live-toast--info .gf-live-toast__label{color:#99f6e4;background:rgba(20,184,166,.16)}
@media(max-width:900px){.gf-search-grid{grid-template-columns:1fr}.gf-live-toast{left:16px;right:16px;bottom:16px;width:auto}}


/* Pré-produção ao vivo */
[data-gf-preprod-watch] [data-gf-preprod-title]{transition:color .16s ease}
[data-gf-guest-row][data-gf-accepted="1"]{background:rgba(52,211,153,.045)}
[data-gf-presenter-status] .gf-badge--approved,
[data-gf-guest-status] .gf-badge--approved{white-space:nowrap}


/* Dashboard administrativa: grade executiva limpa */
.gf-admin-dashboard{display:flex;flex-direction:column;gap:16px;min-width:0}
.gf-admin-dashboard>.mb-3{margin-bottom:0!important}
.gf-admin-dashboard .gf-panel--fill{width:100%;height:100%;min-width:0;display:flex;flex-direction:column}
.gf-admin-dashboard .gf-panel--fill>.gf-panel__body,
.gf-admin-dashboard .gf-panel--fill>.gf-panel__body--flush{flex:1;min-height:0}
.gf-admin-dashboard .gf-admin-kpi-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;align-items:stretch}
.gf-admin-dashboard .gf-kpi{height:100%;min-height:132px;padding:16px;display:flex;flex-direction:column;justify-content:space-between;gap:10px;overflow:hidden}
.gf-admin-dashboard .gf-kpi__head{display:flex;align-items:flex-start;gap:10px;min-height:36px}
.gf-admin-dashboard .gf-kpi__ico{width:32px;height:32px;flex:0 0 32px}
.gf-admin-dashboard .gf-kpi__label{line-height:1.22;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.gf-admin-dashboard .gf-kpi__value{font-size:34px;line-height:1;font-variant-numeric:tabular-nums;letter-spacing:-.04em}
.gf-admin-dashboard .gf-kpi__delta{min-height:32px;line-height:1.25;display:flex;align-items:flex-end;margin:0}
.gf-admin-dashboard .gf-admin-split{display:grid!important;grid-template-columns:repeat(12,minmax(0,1fr));gap:16px;align-items:stretch}
.gf-admin-dashboard .gf-admin-split>[class*="gf-col-"]{display:flex;min-width:0}
.gf-admin-dashboard .gf-admin-split--health .gf-admin-health-col{grid-column:span 4}
.gf-admin-dashboard .gf-admin-split--health .gf-admin-sector-col{grid-column:span 8}
.gf-admin-dashboard .gf-admin-split--alerts .gf-admin-alerts-col{grid-column:span 5}
.gf-admin-dashboard .gf-admin-split--alerts .gf-admin-metrics-col{grid-column:span 7}
.gf-admin-dashboard .gf-panel__head{min-height:64px;align-items:flex-start;gap:12px}
.gf-admin-dashboard .gf-panel__head>div{min-width:0}
.gf-admin-dashboard .gf-panel__title,.gf-admin-dashboard .gf-panel__sub{line-height:1.25;white-space:normal}
.gf-admin-dashboard .gf-admin-health-col .gf-panel__body{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:18px}
.gf-admin-dashboard .gf-health{min-height:210px;justify-content:center}
.gf-admin-dashboard .gf-admin-health-col .gf-note-list{width:100%;border-top:1px solid var(--gf-divider);padding:12px 0 0;margin:12px 0 0!important;list-style:none;color:var(--gf-text-3);font-size:12.5px;line-height:1.45}
.gf-admin-dashboard .gf-table-wrap{width:100%;overflow:auto}
.gf-admin-dashboard .gf-table-wrap--admin{max-height:365px}
.gf-admin-dashboard .gf-table{width:100%}
.gf-table--fixed{table-layout:fixed}
.gf-admin-dashboard .gf-table th,.gf-admin-dashboard .gf-table td{vertical-align:middle;white-space:nowrap}
.gf-admin-dashboard .gf-table th:first-child,.gf-admin-dashboard .gf-table td:first-child{width:32%;min-width:220px;white-space:normal}
.gf-admin-dashboard .gf-table th:nth-child(n+2),.gf-admin-dashboard .gf-table td:nth-child(n+2){text-align:center}
.gf-admin-dashboard .gf-table td:first-child .text-muted{margin-top:2px;line-height:1.25}
.gf-admin-dashboard .gf-admin-alerts-col [data-gf-live-list="action_items"]{max-height:390px;overflow:auto;padding-right:2px}
.gf-admin-dashboard .gf-action-line{min-height:60px;align-items:center;padding:11px 0}
.gf-admin-dashboard .gf-mini-kpi-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;align-items:stretch}
.gf-admin-dashboard .gf-mini-kpi-grid a{min-height:94px;justify-content:center;align-items:flex-start}
.gf-admin-dashboard .gf-timeline{max-height:330px;overflow:auto;padding-right:4px}
.gf-admin-dashboard .gf-tl-item{grid-template-columns:58px 20px minmax(0,1fr)}
.gf-admin-dashboard .gf-tl-body,.gf-admin-dashboard .gf-tl-meta{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
@media(max-width:1280px){
  .gf-admin-dashboard .gf-admin-kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .gf-admin-dashboard .gf-admin-split--health .gf-admin-health-col,.gf-admin-dashboard .gf-admin-split--alerts .gf-admin-alerts-col{grid-column:span 5}
  .gf-admin-dashboard .gf-admin-split--health .gf-admin-sector-col,.gf-admin-dashboard .gf-admin-split--alerts .gf-admin-metrics-col{grid-column:span 7}
}
@media(max-width:1100px){
  .gf-admin-dashboard .gf-admin-split{grid-template-columns:1fr!important}
  .gf-admin-dashboard .gf-admin-split>[class*="gf-col-"]{grid-column:auto!important}
  .gf-admin-dashboard .gf-admin-health-col .gf-panel__body{min-height:0}
  .gf-admin-dashboard .gf-health{min-height:160px}
}
@media(max-width:720px){
  .gf-admin-dashboard .gf-admin-kpi-grid,.gf-admin-dashboard .gf-mini-kpi-grid{grid-template-columns:1fr!important}
  .gf-admin-dashboard .gf-kpi{min-height:118px}
  .gf-admin-dashboard .gf-panel__head{min-height:auto;flex-direction:column;align-items:flex-start}
  .gf-admin-dashboard .gf-table-wrap--admin{max-height:none}
  .gf-admin-dashboard .gf-table th:first-child,.gf-admin-dashboard .gf-table td:first-child{min-width:180px}
}

/* Minhas ações: central de demandas direcionadas */
.gf-actions-summary .gf-kpi{min-height:124px}
.gf-actions-board{display:flex;flex-direction:column;gap:14px}
.gf-actions-group .gf-panel__head{align-items:flex-start;gap:12px}
.gf-actions-list{display:flex;flex-direction:column}
.gf-action-card{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px 16px;border-bottom:1px solid var(--gf-divider);text-decoration:none;color:inherit;transition:background .14s ease,border-color .14s ease}
.gf-action-card:last-child{border-bottom:0}
.gf-action-card:hover{background:var(--gf-bg-2)}
.gf-action-card__main{display:flex;align-items:flex-start;gap:11px;min-width:0}
.gf-action-card__main>div{min-width:0;display:flex;flex-direction:column;gap:4px}
.gf-action-card strong{font-size:13.5px;color:var(--gf-text-1);line-height:1.25}
.gf-action-card small{font-size:12px;color:var(--gf-text-3);line-height:1.35}
.gf-action-card .gf-btn{flex:0 0 auto;pointer-events:none}
@media(max-width:760px){.gf-action-card{align-items:flex-start;flex-direction:column}.gf-action-card .gf-btn{width:100%;justify-content:center}.gf-actions-summary{grid-template-columns:1fr!important}}

/* Pré-produção: edição segura de participantes e status de exibição */
.gf-badge--air{
  background:linear-gradient(135deg,rgba(52,211,153,.16),rgba(34,197,94,.08));
  color:var(--gf-emerald);
  border:1px solid rgba(52,211,153,.28);
  box-shadow:0 0 0 1px rgba(52,211,153,.04),0 0 18px rgba(52,211,153,.08);
}
.gf-badge--air::before{animation:gfAirGlow 1.8s ease-in-out infinite;background:var(--gf-emerald)}
@keyframes gfAirGlow{0%,100%{opacity:.65;transform:scale(.95)}50%{opacity:1;transform:scale(1.22)}}
.gf-compact-list--guests{max-height:480px}
.gf-row-action-stack{display:flex;align-items:flex-end;justify-content:flex-end;gap:8px;flex-wrap:wrap}
.gf-inline-editor{position:relative;text-align:left}
.gf-inline-editor>summary{list-style:none;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--gf-border);border-radius:10px;padding:7px 10px;font-size:12px;font-weight:800;color:var(--gf-text-2);background:var(--gf-bg-2)}
.gf-inline-editor>summary::-webkit-details-marker{display:none}
.gf-inline-editor[open]>summary{border-color:var(--gf-accent-line);color:var(--gf-text-1)}
.gf-inline-editor__form,.gf-inline-editor__remove{display:grid;grid-template-columns:minmax(160px,1fr) minmax(160px,1fr) minmax(140px,1fr) auto;gap:8px;align-items:center;margin:10px 0 0;padding:10px;border:1px solid var(--gf-border);border-radius:var(--gf-r-md);background:var(--gf-bg-1);box-shadow:0 14px 36px rgba(0,0,0,.18)}
.gf-inline-editor__remove{grid-template-columns:auto;justify-content:end;margin-top:6px;padding:0;border:0;background:transparent;box-shadow:none}
.gf-add-guest-box{margin-top:14px;padding:14px;border:1px solid var(--gf-border);border-radius:var(--gf-r-lg);background:rgba(255,255,255,.025);display:grid;grid-template-columns:minmax(220px,.8fr) minmax(0,1.8fr);gap:14px;align-items:end}
.gf-add-guest-form{display:grid;grid-template-columns:minmax(160px,1fr) minmax(160px,1fr) minmax(140px,1fr) auto;gap:8px;align-items:center;margin:0}
@media(max-width:980px){.gf-add-guest-box,.gf-add-guest-form,.gf-inline-editor__form{grid-template-columns:1fr}.gf-row-action-stack{justify-content:flex-start}.gf-inline-editor__remove{justify-content:stretch}.gf-inline-editor__remove .gf-btn{width:100%;justify-content:center}}

/* Saúde operacional: leitura contextual por setor */
.gf-sector-context{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px 16px;border:1px solid var(--gf-border);border-radius:var(--gf-r-lg);background:linear-gradient(135deg,rgba(255,255,255,.035),rgba(255,255,255,.015));box-shadow:var(--gf-shadow-soft)}
.gf-sector-context>div{min-width:0;display:flex;flex-direction:column;gap:6px}
.gf-sector-context strong{font-size:14px;color:var(--gf-text-1);line-height:1.25}
.gf-sector-context small{font-size:12.5px;color:var(--gf-text-2);line-height:1.45;max-width:980px}
@media(max-width:760px){.gf-sector-context{align-items:flex-start;flex-direction:column}.gf-sector-context .gf-btn{width:100%;justify-content:center}}

/* Navegação contextual sem recarregar a página inteira */
.gf-chain-region{position:relative;min-width:0}
.gf-chain-region.is-loading{opacity:.72;pointer-events:none;transition:opacity .12s ease}
.gf-chain-region.is-loading::after{content:'Atualizando seção…';position:absolute;top:10px;right:10px;z-index:3;padding:6px 9px;border-radius:999px;background:var(--gf-bg-2);border:1px solid var(--gf-border);box-shadow:var(--gf-shadow-sm);font-size:11px;font-weight:800;color:var(--gf-text-2)}

/* Fluxos interrompidos: retomada e liberação controlada */
.gf-interrupted-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}
.gf-interrupted-actions .gf-inline-form {
  margin: 0;
}
@media (max-width: 760px) {
  .gf-interrupted-actions,
  .gf-interrupted-actions .gf-inline-form {
    width: 100%;
  }
  .gf-interrupted-actions .gf-input,
  .gf-interrupted-actions .gf-btn {
    width: 100%;
  }
}

/* Pautas externas e ao vivo: dados compactos e leitura de campo */
.gf-info{border:1px solid var(--gf-border);background:linear-gradient(135deg,rgba(255,255,255,.055),rgba(255,255,255,.018));border-radius:16px;padding:12px;min-width:0;box-shadow:inset 0 1px 0 rgba(255,255,255,.035)}
.gf-info small{display:block;color:var(--gf-text-3);font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.04em;margin-bottom:4px}
.gf-info strong{display:block;color:var(--gf-text-1);font-size:13.5px;line-height:1.35;word-break:break-word}
.gf-archive-note{display:flex;gap:10px;align-items:flex-start;padding:12px 14px;border-radius:var(--gf-r-lg);border:1px solid var(--gf-border);background:rgba(44,124,255,.08);color:var(--gf-text-2);font-size:12.5px;line-height:1.45}
.gf-archive-note strong{display:block;color:var(--gf-text-1);font-size:13px;margin-bottom:2px}
.gf-reprise-marker{display:flex;gap:10px;align-items:flex-start;padding:12px 14px;border:1px solid rgba(52,211,153,.24);border-radius:var(--gf-r-lg);background:rgba(52,211,153,.09);color:var(--gf-text-2);font-size:12.5px}
.gf-reprise-marker strong{display:block;color:var(--gf-emerald);font-size:13px;margin-bottom:2px}

/* Programas ao vivo: operação em tempo real */
.gf-live-pulse{display:inline-flex;align-items:center;gap:7px;font-size:12px;font-weight:800;color:var(--gf-emerald)}
.gf-live-pulse::before{content:'';width:8px;height:8px;border-radius:50%;background:var(--gf-emerald);box-shadow:0 0 0 0 rgba(16,185,129,.36);animation:gfLivePulse 1.6s infinite}
@keyframes gfLivePulse{0%{box-shadow:0 0 0 0 rgba(16,185,129,.36)}70%{box-shadow:0 0 0 10px rgba(16,185,129,0)}100%{box-shadow:0 0 0 0 rgba(16,185,129,0)}}

/* v2.2.30 · Registro final da equipe operacional presente */
.gf-crew-field{padding:12px;border:1px solid var(--gf-border);border-radius:var(--gf-r-lg);background:rgba(255,255,255,.025)}
.gf-crew-field textarea{font-size:12.5px;line-height:1.45;min-height:132px}
.gf-crew-list{display:grid;gap:8px}
.gf-crew-card{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;padding:10px 12px;border:1px solid var(--gf-border);border-radius:var(--gf-r-md);background:linear-gradient(135deg,rgba(255,255,255,.045),rgba(255,255,255,.016));box-shadow:inset 0 1px 0 rgba(255,255,255,.035)}
.gf-crew-card strong{display:block;color:var(--gf-text-1);font-size:13px;line-height:1.25}
.gf-crew-card span{display:inline-flex;margin-top:4px;padding:3px 7px;border:1px solid var(--gf-border);border-radius:999px;color:var(--gf-text-2);font-size:11px;font-weight:800;background:rgba(255,255,255,.035)}
.gf-crew-card p{margin:0;max-width:55%;color:var(--gf-text-3);font-size:12px;line-height:1.35;text-align:right}
@media(max-width:760px){.gf-crew-card{display:block}.gf-crew-card p{max-width:none;text-align:left;margin-top:8px}}

/* v2.2.32 · Fluxo claro de pautas externas e exibição */
.gf-badge--info{background:var(--gf-cyan-bg);color:var(--gf-cyan)}
.gf-field-flow{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:10px;align-items:stretch}
.gf-field-flow__step{position:relative;display:flex;gap:9px;align-items:flex-start;padding:12px;border:1px solid var(--gf-border);border-radius:var(--gf-r-lg);background:rgba(255,255,255,.025);min-width:0}
.gf-field-flow__dot{width:12px;height:12px;border-radius:99px;background:var(--gf-bg-3);border:2px solid rgba(255,255,255,.12);margin-top:2px;flex:0 0 auto}
.gf-field-flow__step strong{display:block;color:var(--gf-text-1);font-size:12.5px;line-height:1.25;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.gf-field-flow__step small{display:block;color:var(--gf-text-3);font-size:11px;line-height:1.35;margin-top:2px}
.gf-field-flow__step.is-done{border-color:rgba(52,211,153,.22);background:rgba(52,211,153,.07)}
.gf-field-flow__step.is-done .gf-field-flow__dot{background:var(--gf-emerald);box-shadow:0 0 0 3px rgba(52,211,153,.13)}
.gf-field-flow__step.is-active{border-color:var(--gf-accent-line);background:rgba(44,124,255,.09)}
.gf-field-flow__step.is-active .gf-field-flow__dot{background:var(--gf-accent);box-shadow:0 0 0 3px var(--gf-accent-soft)}
.gf-field-flow__step.is-blocked{border-color:rgba(248,113,113,.28);background:rgba(248,113,113,.07)}
.gf-field-flow__step.is-blocked .gf-field-flow__dot{background:var(--gf-red)}
.gf-checkline{display:flex;align-items:center;gap:8px;margin:8px 0 12px;color:var(--gf-text-2);font-size:12.5px;font-weight:700}
.gf-checkline input{accent-color:var(--gf-accent)}
.gf-air-form{padding:12px;border:1px solid var(--gf-accent-line);border-radius:var(--gf-r-lg);background:rgba(44,124,255,.06)}
@media(max-width:1020px){.gf-field-flow{grid-template-columns:repeat(3,minmax(0,1fr))}}
@media(max-width:640px){.gf-field-flow{grid-template-columns:1fr}}

/* v2.2.33 · Central de pautas externas e saídas com múltiplas pautas */
.gf-field-create{border-color:var(--gf-accent-line);box-shadow:0 18px 55px rgba(44,124,255,.08)}
.gf-section-label{display:flex;align-items:center;gap:8px;margin:4px 0 10px;color:var(--gf-text-1);font-size:12px;font-weight:900;text-transform:uppercase;letter-spacing:.055em}
.gf-section-label::before{content:'';width:8px;height:8px;border-radius:99px;background:var(--gf-accent);box-shadow:0 0 0 3px var(--gf-accent-soft)}
.gf-field-items{display:grid;gap:12px;margin-top:8px}
.gf-field-item{border:1px solid var(--gf-border);border-radius:var(--gf-r-lg);background:linear-gradient(135deg,rgba(255,255,255,.045),rgba(255,255,255,.016));padding:14px;box-shadow:inset 0 1px 0 rgba(255,255,255,.035)}
.gf-field-item__head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}
.gf-field-item__head strong{color:var(--gf-text-1);font-size:13px}
.gf-table tr.is-current-row{background:rgba(44,124,255,.09)}
.gf-table tr.is-current-row td:first-child{box-shadow:inset 3px 0 0 var(--gf-accent)}
@media(max-width:760px){.gf-field-item{padding:12px}.gf-field-item__head{align-items:flex-start;flex-direction:column}.gf-field-item__head .gf-btn{width:100%;justify-content:center}}


/* v2.2.47 · Formulários sob demanda */
.gf-create-panel{border-color:var(--gf-accent-line);box-shadow:0 18px 55px rgba(44,124,255,.08)}
.gf-page-actions{display:flex;align-items:center;justify-content:flex-end;gap:8px;flex-wrap:wrap}
.gf-page-actions form{display:flex;align-items:center;gap:8px}
@media(max-width:760px){.gf-page-actions{width:100%;justify-content:stretch}.gf-page-actions .gf-btn,.gf-page-actions form,.gf-page-actions .gf-select{width:100%;justify-content:center}}


/* v2.2.48 · Modal real para edição de vínculos */
.gf-user-editor-modal{box-sizing:border-box}
.gf-user-editor-modal *{box-sizing:border-box}

/* v2.2.49 · Editor de vínculos mais claro e orientado para usuários leigos */
.gf-user-editor-popover--wide{width:min(980px,calc(100vw - 32px))!important;padding:0!important;overflow:hidden!important;display:flex;flex-direction:column;background:linear-gradient(180deg,var(--gf-bg-1),var(--gf-bg-2))!important}
.gf-user-editor-popover--wide > *{flex:0 0 auto}
.gf-user-editor-popover--wide .gf-user-editor-form{flex:1 1 auto;overflow:auto;padding:0 20px 18px;max-height:none}
.gf-user-editor-head--clear{top:0!important;margin:0!important;padding:18px 20px!important;background:linear-gradient(180deg,var(--gf-bg-1),rgba(15,23,42,.96))!important;border-bottom:1px solid var(--gf-divider)!important}
.gf-user-editor-titleblock{min-width:0}
.gf-kicker{display:inline-flex;margin-bottom:6px;color:var(--gf-accent);font-size:10.5px;font-weight:900;text-transform:uppercase;letter-spacing:.08em}
.gf-user-editor-summary{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px 20px;border-bottom:1px solid var(--gf-divider);background:rgba(255,255,255,.025)}
.gf-user-editor-person{display:flex;align-items:center;gap:10px;min-width:0}
.gf-user-editor-person strong{display:block;color:var(--gf-text-1);font-size:14px;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.gf-user-editor-person span{display:block;color:var(--gf-text-3);font-size:12px;line-height:1.35;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:520px}
.gf-user-editor-tags{display:flex;gap:6px;flex-wrap:wrap;justify-content:flex-end}
.gf-user-editor-guide{display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding:12px 20px;border-bottom:1px solid var(--gf-divider);background:rgba(44,124,255,.055);color:var(--gf-text-2);font-size:12.5px;line-height:1.35}
.gf-user-editor-guide strong{color:var(--gf-text-1);font-weight:900}
.gf-user-editor-guide span{display:inline-flex;align-items:center;padding:4px 8px;border:1px solid var(--gf-border);border-radius:999px;background:rgba(255,255,255,.035);font-weight:700}
.gf-user-editor-section{margin-top:14px;padding:14px;border:1px solid var(--gf-border);border-radius:var(--gf-r-lg);background:linear-gradient(135deg,rgba(255,255,255,.045),rgba(255,255,255,.018));box-shadow:inset 0 1px 0 rgba(255,255,255,.035)}
.gf-user-editor-section__head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px}
.gf-user-editor-section__head div{display:flex;align-items:center;gap:8px;min-width:0}
.gf-user-editor-section__head div span{display:inline-grid;place-items:center;flex:0 0 auto;width:24px;height:24px;border-radius:999px;background:var(--gf-accent);color:white;font-size:12px;font-weight:900;box-shadow:0 0 0 4px var(--gf-accent-soft)}
.gf-user-editor-section__head strong{color:var(--gf-text-1);font-size:14px;line-height:1.25}
.gf-user-editor-section__head p{margin:0;max-width:390px;color:var(--gf-text-3);font-size:12.2px;line-height:1.4;text-align:right}
.gf-user-editor-toolbar{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}
.gf-user-editor-toolbar .gf-input{max-width:360px;height:36px}
.gf-user-editor-toolbar small{color:var(--gf-text-3);font-size:11.5px;font-weight:800;white-space:nowrap}
.gf-input--sm{height:36px;font-size:12.5px}
.gf-checkgrid--scroll{max-height:190px;overflow:auto;padding:10px;border:1px solid var(--gf-border);border-radius:var(--gf-r-md);background:rgba(2,8,23,.18)}
.gf-chip--choice{justify-content:flex-start;text-align:left;line-height:1.25;min-height:34px;cursor:pointer}
.gf-chip--choice input{accent-color:var(--gf-accent);flex:0 0 auto}
.gf-chip--choice span{min-width:0;overflow:hidden;text-overflow:ellipsis}
.gf-empty-mini{padding:10px 12px;border:1px dashed var(--gf-border);border-radius:var(--gf-r-md);color:var(--gf-text-3);font-size:12.5px;background:rgba(255,255,255,.025)}
.gf-user-editor-actions--clear{bottom:0!important;margin:16px -20px -18px!important;padding:14px 20px!important;justify-content:flex-end!important;gap:10px!important;background:linear-gradient(0deg,var(--gf-bg-2),rgba(15,23,42,.94))!important}
.gf-user-editor-section--danger{margin:0 20px 18px;border-color:rgba(248,113,113,.22);background:rgba(248,113,113,.055)}
.gf-user-editor-section--danger .gf-user-editor-section__head div span{background:var(--gf-red);box-shadow:0 0 0 4px rgba(248,113,113,.14)}
.gf-user-admin-actions--cards{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:0!important;padding:0!important;border:0!important;background:transparent!important}
.gf-user-admin-card{display:grid;grid-template-columns:1fr auto;grid-template-areas:'title btn' 'desc btn';gap:2px 12px;align-items:center;padding:12px;border:1px solid var(--gf-border);border-radius:var(--gf-r-md);background:rgba(2,8,23,.18)}
.gf-user-admin-card strong{grid-area:title;color:var(--gf-text-1);font-size:13px}
.gf-user-admin-card span{grid-area:desc;color:var(--gf-text-3);font-size:12px;line-height:1.35}
.gf-user-admin-card .gf-btn{grid-area:btn;align-self:center}
@media(max-width:760px){.gf-user-editor-modal{padding:10px!important;align-items:stretch!important}.gf-user-editor-popover--wide{width:100%!important;height:calc(100vh - 20px)!important;max-height:none!important}.gf-user-editor-head--clear{align-items:flex-start}.gf-user-editor-summary{align-items:flex-start;flex-direction:column}.gf-user-editor-person span{max-width:calc(100vw - 92px)}.gf-user-editor-guide{align-items:flex-start;flex-direction:column}.gf-user-editor-section__head{display:block}.gf-user-editor-section__head div{margin-bottom:6px}.gf-user-editor-section__head p{text-align:left;max-width:none}.gf-user-editor-toolbar{display:block}.gf-user-editor-toolbar .gf-input{max-width:none;width:100%;margin-bottom:6px}.gf-checkgrid--scroll{max-height:230px}.gf-user-admin-actions--cards{grid-template-columns:1fr}.gf-user-admin-card{grid-template-columns:1fr;grid-template-areas:'title' 'desc' 'btn'}.gf-user-admin-card .gf-btn{width:100%;justify-content:center;margin-top:8px}.gf-user-editor-actions--clear{flex-direction:column-reverse}.gf-user-editor-actions--clear .gf-btn{width:100%;justify-content:center}}


/* =========================================================
   LAB MOBILE PREVIEW · base v2.2.49
   Responsividade experimental para validação em subdomínio.
   Não altera a numeração oficial nem o motor de atualização.
   ========================================================= */
.gf-mobile-menu,.gf-mobile-close,.gf-mobile-backdrop{display:none}

@media (max-width: 900px){
  html,body{min-width:0;overflow-x:hidden}
  body.gf-mobile-nav-open{overflow:hidden}
  .gf-app{display:block;min-height:100vh}
  .gf-main{display:block;min-height:100vh;margin:0}
  .gf-content{padding:14px 12px 88px;overflow:visible}

  .gf-mobile-menu{display:inline-flex;align-items:center;gap:8px;height:38px;padding:0 11px;border:1px solid var(--gf-border);border-radius:12px;background:var(--gf-bg-2);color:var(--gf-text-1);font-weight:900;font-size:12px;flex:0 0 auto}
  .gf-mobile-menu span{font-size:16px;line-height:1}.gf-mobile-menu strong{font-size:12px}
  .gf-mobile-close{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;margin-left:auto;border:1px solid var(--gf-border);border-radius:10px;background:var(--gf-bg-2);color:var(--gf-text-1);font-size:21px;line-height:1}
  .gf-mobile-backdrop{display:block;position:fixed;inset:0;z-index:139;background:rgba(0,0,0,.54);opacity:0;pointer-events:none;transition:opacity .16s ease;backdrop-filter:blur(2px)}
  body.gf-mobile-nav-open .gf-mobile-backdrop{opacity:1;pointer-events:auto}

  .gf-sidebar{position:fixed!important;top:0;left:0;bottom:0;z-index:140;width:min(326px,86vw);height:100vh;min-height:0;display:flex!important;flex-direction:column;padding:12px;border-right:1px solid var(--gf-border);border-bottom:0;transform:translateX(-105%);transition:transform .18s ease;background:var(--gf-bg-1);box-shadow:24px 0 70px rgba(0,0,0,.42)}
  body.gf-mobile-nav-open .gf-sidebar{transform:translateX(0)}
  .gf-sidebar__logo{justify-content:flex-start;padding:4px 4px 14px;margin-bottom:10px}.gf-sidebar__logo img{height:32px!important;max-width:210px;object-fit:contain}
  .gf-sidebar__nav{display:flex!important;flex-direction:column;overflow:auto;padding:0;gap:2px;min-height:0;flex:1}
  .gf-sidebar__foot{display:flex!important;border-top:1px solid var(--gf-divider);padding-top:10px}.gf-user-chip__name,.gf-user-chip__role{display:block!important}.gf-user-chip{padding:9px 8px}
  .gf-nav-group{display:block!important;padding:13px 8px 6px;font-size:10px;color:var(--gf-text-4)}
  .gf-nav-item{justify-content:flex-start!important;white-space:normal;padding:10px 9px;font-size:13.5px}.gf-nav-item span:not(.gf-nav-badge){display:inline-flex!important}.gf-nav-badge{margin-left:auto}

  .gf-topbar{position:sticky;top:0;z-index:60;height:auto;min-height:58px;padding:9px 10px;gap:8px;flex-wrap:wrap;background:rgba(13,17,28,.96);backdrop-filter:blur(14px)}
  .gf-crumbs{flex:1 1 auto;min-width:0}.gf-crumbs span:first-child,.gf-crumbs__sep{display:none}.gf-crumbs__current{display:block;max-width:46vw;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:13px}
  .gf-topbar__search{order:9;display:flex!important;width:100%;margin:2px 0 0;padding:8px 10px}.gf-topbar__search kbd{display:none}
  .gf-topbar .gf-btn{height:36px;padding:0 10px}.gf-topbar>div[style*="width:1px"]{display:none!important}

  .gf-page-head{display:block;margin-bottom:14px}.gf-page-title{font-size:20px;line-height:1.18}.gf-page-sub{font-size:12.5px;line-height:1.45}.gf-page-actions{width:100%;display:grid!important;grid-template-columns:1fr;gap:8px;margin-top:12px;justify-content:stretch!important}.gf-page-actions .gf-btn,.gf-page-actions form,.gf-page-actions .gf-select,.gf-page-actions .gf-input{width:100%;justify-content:center}

  .gf-grid,.gf-admin-dashboard .gf-admin-kpi-grid,.gf-admin-dashboard .gf-mini-kpi-grid{grid-template-columns:1fr!important}.gf-col-3,.gf-col-4,.gf-col-5,.gf-col-7,.gf-col-8,.gf-col-9,.gf-col-12{grid-column:auto!important}.gf-kpi{min-height:auto;padding:14px}.gf-kpi__value{font-size:28px}.gf-panel{border-radius:14px}.gf-panel__head{align-items:flex-start;flex-direction:column;gap:8px;padding:13px 14px}.gf-panel__body{padding:14px;overflow-x:auto}.gf-panel__body--flush{padding:0;overflow-x:auto}.gf-panel__title{font-size:14px}.gf-panel__sub{font-size:12px}

  .gf-table{min-width:720px}.gf-table th,.gf-table td{padding:10px 11px}.gf-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}.gf-prod-head{display:none}.gf-prod-row{display:grid;grid-template-columns:42px 1fr;gap:8px;padding:12px}.gf-prod-row>div:nth-child(n+3){grid-column:2}.gf-prod-row .right{text-align:left}.gf-mini-row{grid-template-columns:1fr;gap:6px}

  .gf-tabs{display:flex;overflow-x:auto;white-space:nowrap;gap:6px;padding-bottom:6px;margin-bottom:14px;-webkit-overflow-scrolling:touch}.gf-tabs a{flex:0 0 auto}.gf-kanban{grid-template-columns:1fr!important;gap:10px;overflow:visible}.gf-kanban__col{min-height:0}.gf-kanban__col-body{max-height:none}.gf-flow-labels{display:none!important}

  .gf-field,.gf-grid .gf-field{min-width:0}.gf-grid--cols-2,.gf-grid--cols-3,.gf-grid--cols-4,.gf-grid--cols-12{grid-template-columns:1fr!important}.gf-input,.gf-select,.gf-textarea{font-size:16px}.gf-inline-form,.gf-actionbar{display:grid!important;grid-template-columns:1fr;align-items:stretch;width:100%;gap:8px}.gf-inline-form .gf-input,.gf-inline-form .gf-select,.gf-inline-form .gf-btn,.gf-actionbar .gf-btn{width:100%!important;justify-content:center}.gf-btn{min-height:38px}.gf-btn-group{display:grid!important;grid-template-columns:1fr;gap:8px;width:100%}

  .gf-login{grid-template-columns:1fr;min-height:100vh}.gf-login__aside{min-height:auto;padding:28px 22px}.gf-login__aside h1{font-size:26px!important;max-width:none}.gf-login__main{padding:22px}.gf-login__form{width:100%}.gf-login__logo img{height:34px}

  .gf-user-editor-modal{padding:0!important;align-items:stretch!important}.gf-user-editor-popover,.gf-user-editor-popover--wide{width:100%!important;height:100vh!important;max-height:none!important;border-radius:0!important}.gf-user-editor-popover--wide .gf-user-editor-form{padding:0 14px 16px}.gf-user-editor-head--clear,.gf-user-editor-summary,.gf-user-editor-guide{padding-left:14px!important;padding-right:14px!important}.gf-user-editor-section{padding:12px}.gf-user-editor-section--danger{margin:0 14px 16px}.gf-checkgrid--scroll{max-height:260px}.gf-user-editor-actions--clear{margin-left:-14px!important;margin-right:-14px!important;padding-left:14px!important;padding-right:14px!important}

  .gf-live-toast{left:10px!important;right:10px!important;bottom:10px!important;width:auto!important;border-radius:16px}.gf-live-toast__content{padding:13px 42px 13px 14px}.gf-public__card{width:auto;margin:12px}.hide-mobile{display:none!important}
}

@media (max-width: 420px){
  .gf-content{padding-left:10px;padding-right:10px}.gf-topbar__search{font-size:12px}.gf-crumbs__current{max-width:40vw}.gf-page-title{font-size:19px}.gf-kpi__value{font-size:26px}.gf-panel__body{padding:12px}.gf-user-editor-guide span{width:100%;justify-content:center}.gf-table{min-width:680px}.gf-sidebar{width:90vw}
}


/* =========================================================
   LAB MOBILE PREVIEW · ajuste de legibilidade mobile
   Corrige modal de vínculos e login em telas pequenas.
   ========================================================= */
@media (max-width: 900px){
  /* Login mobile: acesso mais direto, sem ocupar a tela com a peça institucional inteira */
  body:has(.gf-login){background:radial-gradient(circle at 18% 0%, rgba(44,124,255,.24), transparent 42%), radial-gradient(circle at 90% 12%, rgba(0,184,255,.14), transparent 34%), var(--gf-bg-0)}
  .gf-login{display:flex!important;flex-direction:column!important;min-height:100svh!important;background:transparent!important}
  .gf-login__aside{display:block!important;min-height:0!important;padding:24px 20px 10px!important;border-right:0!important;background:transparent!important;text-align:left!important}
  .gf-login__logo{display:flex;justify-content:center;margin-bottom:18px}
  .gf-login__logo img{height:38px!important;max-width:230px;object-fit:contain}
  .gf-login__aside > div:nth-child(2){max-width:420px;margin:0 auto;text-align:center}
  .gf-login__aside > div:nth-child(2) > div:first-child{font-size:10px!important;color:var(--gf-accent)!important;margin-bottom:6px}
  .gf-login__aside h1{font-size:23px!important;line-height:1.12!important;margin:6px auto 8px!important;max-width:360px!important}
  .gf-login__aside p{font-size:12.6px!important;line-height:1.45!important;max-width:360px!important;margin:0 auto!important;color:var(--gf-text-2)!important}
  .gf-login__aside > .text-muted{display:none!important}
  .gf-login__main{display:block!important;padding:12px 16px 24px!important;flex:1 1 auto!important}
  .gf-login__form{width:100%!important;max-width:430px!important;margin:0 auto!important;padding:20px 18px 18px!important;border:1px solid var(--gf-border-strong)!important;border-radius:20px!important;background:linear-gradient(180deg, rgba(19,24,41,.96), rgba(13,17,28,.98))!important;box-shadow:0 22px 70px rgba(0,0,0,.32)!important}
  .gf-login__form h2{font-size:20px!important;text-align:center!important}
  .gf-login__form .text-muted{line-height:1.4!important}
  .gf-login__form > .text-muted:first-of-type{text-align:center!important}
  .gf-login__form .gf-field{margin-top:14px!important}
  .gf-login__form .gf-input{height:46px!important;border-radius:14px!important;font-size:16px!important;background:#0b1020!important;border-color:rgba(255,255,255,.12)!important}
  .gf-login__form .gf-btn{height:46px!important;border-radius:14px!important;font-size:14px!important;margin-top:12px!important}

  /* Editor de vínculos mobile: modal sólido, legível e sem aparência transparente */
  body.gf-user-editor-open{overflow:hidden!important;background:#08090f!important}
  .gf-user-editor-modal{background:#08090f!important;backdrop-filter:none!important;padding:0!important;align-items:stretch!important;justify-content:stretch!important}
  .gf-user-editor-popover,.gf-user-editor-popover--wide{width:100%!important;height:100svh!important;max-height:100svh!important;border:0!important;border-radius:0!important;background:#0d111c!important;box-shadow:none!important;color:var(--gf-text-1)!important}
  .gf-user-editor-popover--wide .gf-user-editor-form{background:#0d111c!important;padding:0 14px 18px!important;overflow:auto!important}
  .gf-user-editor-head--clear{position:sticky!important;top:0!important;z-index:4!important;background:#0d111c!important;border-bottom:1px solid rgba(255,255,255,.10)!important;padding:16px 14px!important;box-shadow:0 14px 30px rgba(0,0,0,.28)!important}
  .gf-user-editor-head--clear .gf-btn{background:#182039!important;border-color:rgba(255,255,255,.14)!important;color:var(--gf-text-1)!important}
  .gf-user-editor-summary{background:#10172a!important;border-bottom:1px solid rgba(255,255,255,.08)!important;padding:13px 14px!important}
  .gf-user-editor-guide{background:#10254d!important;border-bottom:1px solid rgba(44,124,255,.28)!important;color:#c9d5ef!important;padding:12px 14px!important}
  .gf-user-editor-guide span{background:#172b54!important;border-color:rgba(255,255,255,.14)!important;color:#eef1f8!important}
  .gf-user-editor-section{background:#111827!important;border-color:rgba(255,255,255,.10)!important;box-shadow:none!important;margin-top:12px!important;border-radius:16px!important}
  .gf-user-editor-section__head strong{font-size:14px!important}
  .gf-user-editor-section__head p{color:#9aa7c2!important}
  .gf-checkgrid--scroll{background:#0b1020!important;border-color:rgba(255,255,255,.10)!important;max-height:240px!important}
  .gf-chip--choice{background:#151d33!important;border-color:rgba(255,255,255,.10)!important;color:#eef1f8!important;min-height:42px!important;padding:10px 11px!important}
  .gf-chip--choice input{width:17px!important;height:17px!important}
  .gf-user-editor-actions--clear{position:sticky!important;bottom:0!important;background:#0d111c!important;border-top:1px solid rgba(255,255,255,.10)!important;box-shadow:0 -12px 30px rgba(0,0,0,.32)!important}
  .gf-user-editor-section--danger{background:#24131a!important;border-color:rgba(248,113,113,.28)!important}
  .gf-user-admin-card{background:#141b2e!important;border-color:rgba(255,255,255,.10)!important}
}

@media (max-width: 420px){
  .gf-login__aside{padding:20px 16px 8px!important}
  .gf-login__aside h1{font-size:21px!important}
  .gf-login__aside p{font-size:12px!important}
  .gf-login__main{padding:10px 12px 18px!important}
  .gf-login__form{padding:18px 15px!important;border-radius:18px!important}
  .gf-user-editor-head--clear,.gf-user-editor-summary,.gf-user-editor-guide{padding-left:12px!important;padding-right:12px!important}
  .gf-user-editor-popover--wide .gf-user-editor-form{padding-left:12px!important;padding-right:12px!important}
}
