/* =========================================================
   GradeFlow 2.2.2 — base stylesheet
   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; }
}

/* v2.2.2 — 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-editbox{margin-top:12px;padding:12px;border:1px solid var(--gf-border);background:var(--gf-bg-2);border-radius:var(--gf-r-md)}
.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-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}
