/* ============================================================
 * THEME.CSS — Nexus v9 · Kickoff WCS · INVENT "Command"
 * Adaptação do design system "Command" (Dashboard Projetos V2)
 * para o app multi-página Nexus. Brand amarelo #F5C300.
 * Tipografia: Sora (display), Inter (UI), JetBrains Mono (dados).
 * Suporte light/dark via [data-theme]. Compartilhado por todas as páginas.
 * ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Sora:wght@500;600;700;800&family=Inter:wght@400;500;600;700;800&family=JetBrains+Mono:wght@500;700&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --brand:#F5C300;
  --brand-2:#FFDA4B;
  --brand-dim:rgba(245,195,0,.14);
  --brand-ink:#0b0e14;
  --accent:#38bdf8;
  --accent-2:#34d399;
  --bg:#080b11;
  --bg2:#0d121b;
  --panel:#11161f;
  --panel-2:#161c27;
  --surface:rgba(255,255,255,.04);
  --surface2:rgba(255,255,255,.08);
  --border:rgba(255,255,255,.075);
  --border2:rgba(255,255,255,.14);
  --text:#eaf0f8;
  --muted:#7c8699;
  --muted2:#9aa6b8;
  --green:#22c55e; --blue:#38bdf8; --red:#f43f5e; --amber:#f59e0b; --purple:#a855f7;
  /* aliases curtos usados pela lógica de domínio */
  --y:#F5C300; --g:#22c55e; --r:#f43f5e; --b:#4a90d9; --p:#9b82f3; --c:#38bdf8; --o:#f97316;
  --sidebar-w:248px;
  --sidebar-collapsed:68px;
  --radius:16px;
  --radius-sm:10px;
  --shadow:0 18px 50px -18px rgba(0,0,0,.7);
  --font:'Inter',system-ui,sans-serif;
  --font-display:'Sora','Inter',sans-serif;
  --font-mono:'JetBrains Mono',ui-monospace,monospace;
}
[data-theme="light"]{
  --bg:#eef1f6; --bg2:#ffffff; --panel:#ffffff; --panel-2:#f6f8fb;
  --surface:rgba(15,23,42,.035); --surface2:rgba(15,23,42,.06);
  --border:rgba(15,23,42,.09); --border2:rgba(15,23,42,.16);
  --text:#0d1320; --muted:#64748b; --muted2:#475569;
  --shadow:0 14px 40px -18px rgba(15,23,42,.25);
}

html,body{
  height:100%;
  font-family:var(--font);
  color:var(--text);
  overflow:hidden;
  -webkit-font-smoothing:antialiased;
  background:
    radial-gradient(1100px 600px at 100% -8%, rgba(245,195,0,.07), transparent 60%),
    radial-gradient(800px 600px at -8% 4%, rgba(56,189,248,.05), transparent 55%),
    var(--bg);
}
body::before{
  content:'';position:fixed;inset:0;pointer-events:none;z-index:0;opacity:.5;
  background-image:linear-gradient(rgba(255,255,255,.018) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.018) 1px,transparent 1px);
  background-size:46px 46px;
  -webkit-mask-image:radial-gradient(ellipse 80% 60% at 50% 0%,#000,transparent 75%);
          mask-image:radial-gradient(ellipse 80% 60% at 50% 0%,#000,transparent 75%);
}
[data-theme="light"] body::before{opacity:.6;background-image:linear-gradient(rgba(15,23,42,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(15,23,42,.03) 1px,transparent 1px)}
button{cursor:pointer;border:none;background:none;font-family:inherit;color:inherit}
a{color:inherit;text-decoration:none}
input,select,textarea{font-family:inherit}

::-webkit-scrollbar{width:9px;height:9px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:rgba(255,255,255,.1);border-radius:6px;border:2px solid transparent;background-clip:padding-box}
::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.2);background-clip:padding-box}

/* ── Layout ──────────────────────────────────────────────── */
.app{display:flex;height:100vh;overflow:hidden;position:relative;z-index:1}
#main{flex:1;overflow-y:auto;display:flex;flex-direction:column;min-width:0}
.page{padding:26px 30px 70px;animation:rise .5s cubic-bezier(.2,.7,.2,1)}
@keyframes rise{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}

/* ── Sidebar ─────────────────────────────────────────────── */
#sidebar{
  width:var(--sidebar-w);min-width:var(--sidebar-w);
  background:linear-gradient(180deg,var(--bg2),color-mix(in srgb,var(--bg2) 80%, #000));
  border-right:1px solid var(--border);
  display:flex;flex-direction:column;
  transition:width .3s cubic-bezier(.4,0,.2,1),min-width .3s cubic-bezier(.4,0,.2,1);
  position:relative;z-index:10;overflow:hidden;
}
#sidebar.collapsed{width:var(--sidebar-collapsed);min-width:var(--sidebar-collapsed)}
.sb-header{padding:20px 16px 16px;display:flex;align-items:center;gap:11px}
.sb-logo-badge{ /* (não usado no Nexus — logo é texto) */
  width:38px;height:38px;min-width:38px;border-radius:11px;
  background:linear-gradient(140deg,var(--brand),#e0a000);
  display:flex;align-items:center;justify-content:center;
  font-size:19px;font-weight:900;color:var(--brand-ink);flex-shrink:0;
}
.sb-brand{overflow:hidden;line-height:1.2;transition:opacity .2s}
.sb-brand-name{font-family:var(--font-display);font-size:17px;font-weight:800;letter-spacing:-.4px;white-space:nowrap;color:var(--text)}
.sb-brand-name .vy{color:var(--brand)}
.sb-brand-by{font-size:8px;font-weight:700;letter-spacing:1.8px;text-transform:uppercase;color:var(--muted);white-space:nowrap;margin-top:1px}
#sidebar.collapsed .sb-brand{opacity:0;width:0}
#sidebar-toggle{margin-left:auto;color:var(--muted);font-size:18px;padding:4px 7px;border-radius:8px;flex-shrink:0;transition:.2s}
#sidebar-toggle:hover{color:var(--text);background:var(--surface2)}
#sidebar.collapsed #sidebar-toggle{transform:rotate(180deg)}

.sb-nav{flex:1;padding:8px 12px;overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column;gap:2px}
.sb-group{font-size:9.5px;font-weight:800;letter-spacing:1.4px;text-transform:uppercase;color:var(--muted);padding:14px 12px 6px;white-space:nowrap}
#sidebar.collapsed .sb-group{opacity:0;height:8px;padding:4px 0}
.nav-item{
  position:relative;display:flex;align-items:center;gap:13px;
  padding:10px 12px;border-radius:11px;
  color:var(--muted2);font-size:13px;font-weight:600;
  transition:background .16s,color .16s;white-space:nowrap;overflow:hidden;
}
.nav-item:hover{background:var(--surface2);color:var(--text)}
.nav-item.active{background:linear-gradient(90deg,var(--brand-dim),transparent);color:var(--brand)}
.nav-item.active::before{content:'';position:absolute;left:0;top:8px;bottom:8px;width:3px;border-radius:0 3px 3px 0;background:var(--brand);box-shadow:0 0 12px var(--brand)}
.nav-icon{font-size:15px;flex-shrink:0;width:22px;height:22px;display:flex;align-items:center;justify-content:center}
#sidebar.collapsed .nav-label{opacity:0;width:0}

/* project selector na sidebar */
.sb-projsel{margin:8px 12px;padding:9px 12px;border-radius:11px;background:var(--surface);border:1px solid var(--border);cursor:pointer;display:flex;align-items:center;gap:9px;transition:.16s}
.sb-projsel:hover{border-color:var(--brand)}
.sb-projsel .proj-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}
.sb-projsel .ps-name{flex:1;min-width:0;font-size:12.5px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text)}
.sb-projsel .ps-arrow{font-size:10px;color:var(--muted)}
#sidebar.collapsed .sb-projsel .ps-name,#sidebar.collapsed .sb-projsel .ps-arrow{opacity:0;width:0}
.proj-dropdown{margin:0 12px;background:var(--panel-2);border:1px solid var(--border2);border-radius:12px;box-shadow:var(--shadow);padding:6px;overflow:hidden}
.pd-item{display:flex;align-items:center;gap:9px;padding:9px 11px;border-radius:9px;cursor:pointer;transition:.12s}
.pd-item:hover{background:var(--surface2)}
.pd-item.active{background:var(--brand-dim)}
.pd-name{flex:1;font-size:12.5px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pd-meta{font-family:var(--font-mono);font-size:9px;color:var(--muted)}
.pd-new{display:flex;align-items:center;gap:8px;padding:9px 11px;border-radius:9px;cursor:pointer;border-top:1px solid var(--border);margin-top:4px;color:var(--brand);font-size:12.5px;font-weight:700}
.pd-new:hover{background:var(--brand-dim)}

.sb-footer{padding:12px;border-top:1px solid var(--border)}
#sidebar-user{display:flex;align-items:center;gap:11px;padding:8px;border-radius:12px;background:var(--surface)}
.su-avatar{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;color:#fff;flex-shrink:0;background:linear-gradient(140deg,var(--brand),#e0a000);color:var(--brand-ink)}
.su-info{overflow:hidden;flex:1}
.su-nome{font-size:12.5px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.su-papel{font-size:10px;color:var(--muted);text-transform:capitalize}
.su-logout{padding:6px 8px;color:var(--muted);font-size:15px;border-radius:8px;transition:.2s}
.su-logout:hover{color:var(--red);background:var(--surface2)}
#sidebar.collapsed .su-info,#sidebar.collapsed .su-logout{opacity:0;width:0;padding:0}

/* ── Topbar ──────────────────────────────────────────────── */
.topbar{
  padding:16px 30px;display:flex;align-items:center;gap:14px;
  border-bottom:1px solid var(--border);
  background:color-mix(in srgb,var(--bg2) 75%, transparent);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  position:sticky;top:0;z-index:6;
}
.topbar-title{font-family:var(--font-display);font-size:19px;font-weight:800;letter-spacing:-.4px;flex:1;display:flex;align-items:baseline;gap:10px}
.topbar-sub{font-size:12px;color:var(--muted);font-weight:400;font-family:var(--font)}
.topbar-actions{display:flex;align-items:center;gap:9px}

/* ── Botões ──────────────────────────────────────────────── */
.btn-icon{width:38px;height:38px;border-radius:11px;display:flex;align-items:center;justify-content:center;background:var(--surface);border:1px solid var(--border);color:var(--muted2);font-size:15px;transition:.18s}
.btn-icon:hover{background:var(--surface2);color:var(--text);border-color:var(--border2)}
.btn-primary{display:inline-flex;align-items:center;gap:7px;padding:10px 18px;background:linear-gradient(135deg,var(--brand),var(--brand-2));color:var(--brand-ink);font-size:13px;font-weight:700;border-radius:11px;transition:.18s;box-shadow:0 8px 20px -8px rgba(245,195,0,.6)}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 12px 26px -8px rgba(245,195,0,.7)}
.btn-outline{display:inline-flex;align-items:center;gap:6px;padding:9px 15px;background:var(--surface);border:1px solid var(--border2);border-radius:11px;font-size:12.5px;font-weight:600;color:var(--muted2);transition:.18s}
.btn-outline:hover{border-color:var(--brand);color:var(--brand);background:var(--brand-dim)}
.btn-danger{display:inline-flex;align-items:center;gap:6px;padding:9px 15px;background:rgba(244,63,94,.12);border:1px solid rgba(244,63,94,.35);border-radius:11px;font-size:12.5px;font-weight:600;color:#fb7185;transition:.18s}
.btn-danger:hover{background:rgba(244,63,94,.22)}
.btn-sync{display:inline-flex;align-items:center;gap:6px;padding:9px 15px;background:rgba(56,189,248,.12);border:1px solid rgba(56,189,248,.32);border-radius:11px;font-size:12.5px;font-weight:700;color:var(--accent);transition:.18s}
.btn-sync:hover{background:rgba(56,189,248,.2)}

/* ── Cards ───────────────────────────────────────────────── */
.card{
  background:linear-gradient(160deg,var(--panel),var(--panel-2));
  border:1px solid var(--border);
  border-radius:var(--radius);padding:20px;position:relative;overflow:hidden;
  box-shadow:var(--shadow);
  transition:border-color .2s,transform .2s;
}
.card::after{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.14),transparent)}
.card-title{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.8px;color:var(--muted2);margin-bottom:16px;display:flex;align-items:center;justify-content:space-between;gap:8px}
.card-title::before{content:'';display:inline-block;width:3px;height:13px;border-radius:2px;background:var(--brand);margin-right:9px;flex-shrink:0}
.ct-action{font-size:11px;color:var(--muted2);cursor:pointer;font-weight:600;text-transform:none;letter-spacing:0}
.ct-action:hover{color:var(--brand)}

.grid{display:grid;gap:18px}
.bento{display:grid;grid-template-columns:repeat(12,1fr);gap:18px}
.col-3{grid-column:span 3}.col-4{grid-column:span 4}.col-5{grid-column:span 5}
.col-6{grid-column:span 6}.col-7{grid-column:span 7}.col-8{grid-column:span 8}
.col-9{grid-column:span 9}.col-12{grid-column:span 12}

/* ── KPI ─────────────────────────────────────────────────── */
.kpi{display:flex;flex-direction:column;gap:7px}
.kpi-top{display:flex;align-items:flex-start;justify-content:space-between}
.kpi-label{font-size:10.5px;font-weight:800;text-transform:uppercase;letter-spacing:.7px;color:var(--muted)}
.kpi-value{font-family:var(--font-mono);font-size:34px;font-weight:700;letter-spacing:-1.5px;line-height:1}
.kpi-sub{font-size:12px;color:var(--muted2)}
.kpi-icon{font-size:17px;opacity:.7}

/* ── Badges ──────────────────────────────────────────────── */
.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:999px;font-size:11px;font-weight:700;white-space:nowrap;border:1px solid transparent}
.pill{display:inline-flex;align-items:center;gap:5px;padding:5px 11px;border-radius:9px;font-size:11px;font-weight:600;background:var(--surface);border:1px solid var(--border)}

/* ── Tabelas ─────────────────────────────────────────────── */
.table-wrap{overflow-x:auto}
table{width:100%;border-collapse:collapse}
th{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.7px;color:var(--muted);padding:10px 12px;text-align:left;border-bottom:1px solid var(--border2);white-space:nowrap}
td{padding:12px;font-size:13px;border-bottom:1px solid var(--border);vertical-align:middle}
tbody tr{transition:background .14s}
tbody tr:hover td{background:var(--surface2)}

/* ── Forms ───────────────────────────────────────────────── */
.form-group{margin-bottom:15px}
.form-label{display:block;font-size:10.5px;font-weight:800;text-transform:uppercase;letter-spacing:.7px;color:var(--muted);margin-bottom:8px}
.form-control{width:100%;padding:11px 13px;background:var(--surface);border:1px solid var(--border2);border-radius:11px;color:var(--text);font-size:13px;outline:none;transition:.18s}
.form-control:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-dim)}
.form-control::placeholder{color:var(--muted)}
select.form-control option{background:#11161f;color:var(--text)}
[data-theme="light"] select.form-control option{background:#fff}
textarea.form-control{resize:vertical;min-height:72px}

/* ── Toast ───────────────────────────────────────────────── */
#toast-host{position:fixed;bottom:26px;right:26px;z-index:9999;display:flex;flex-direction:column;gap:10px}
.toast{background:var(--panel-2);border:1px solid var(--border2);border-left:3px solid var(--blue);border-radius:12px;padding:13px 17px;font-size:13px;color:var(--text);box-shadow:var(--shadow);opacity:0;transform:translateX(40px);transition:.32s;max-width:360px;display:flex;align-items:center;gap:9px}
.toast.show{opacity:1;transform:none}
.toast.ok{border-left-color:var(--green)}
.toast.warn{border-left-color:var(--brand)}
.toast.err{border-left-color:var(--red)}

/* ── Modal ───────────────────────────────────────────────── */
.modal-overlay{position:fixed;inset:0;background:rgba(5,8,13,.72);backdrop-filter:blur(6px);display:none;align-items:center;justify-content:center;z-index:1000;padding:20px}
.modal-overlay.open{display:flex;animation:rise .25s ease}
.modal{background:linear-gradient(160deg,var(--panel),var(--panel-2));border:1px solid var(--border2);border-radius:18px;width:100%;max-width:480px;max-height:88vh;overflow-y:auto;box-shadow:0 30px 80px rgba(0,0,0,.6)}
.modal-head{padding:20px 24px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.modal-head h3{font-family:var(--font-display);font-size:16px;font-weight:800}
.modal-body{padding:24px}
.modal-foot{padding:16px 24px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:10px}
.modal-close{font-size:22px;color:var(--muted);cursor:pointer}
.modal-close:hover{color:var(--text)}

/* ── Command Palette ─────────────────────────────────────── */
.cmd-overlay{position:fixed;inset:0;background:rgba(5,8,13,.74);backdrop-filter:blur(6px);display:none;align-items:flex-start;justify-content:center;z-index:2000;padding-top:12vh}
.cmd-overlay.open{display:flex}
.cmd{width:100%;max-width:620px;background:linear-gradient(160deg,var(--panel),var(--panel-2));border:1px solid var(--border2);border-radius:16px;overflow:hidden;box-shadow:0 40px 90px rgba(0,0,0,.7)}
.cmd-input{width:100%;padding:19px 22px;background:transparent;border:none;border-bottom:1px solid var(--border);color:var(--text);font-size:16px;outline:none;font-family:var(--font)}
.cmd-input::placeholder{color:var(--muted)}
.cmd-list{max-height:52vh;overflow-y:auto;padding:8px}
.cmd-item{display:flex;align-items:center;gap:12px;padding:12px 15px;border-radius:11px;cursor:pointer}
.cmd-item.sel,.cmd-item:hover{background:var(--brand-dim)}
.ci-ico{width:22px;text-align:center;font-size:15px}
.ci-label{flex:1;font-size:14px;font-weight:600}
.ci-sub{font-size:11px;color:var(--muted)}
.cmd-empty{padding:26px;text-align:center;color:var(--muted);font-size:13px}
.cmd-foot{padding:10px 18px;border-top:1px solid var(--border);font-size:11px;color:var(--muted);display:flex;gap:14px}

/* ── Progress bar ────────────────────────────────────────── */
.pbar{height:8px;border-radius:5px;background:var(--surface2);overflow:hidden}
.pbar>i{display:block;height:100%;border-radius:5px;transition:width .8s cubic-bezier(.4,0,.2,1)}

.empty{text-align:center;padding:48px 20px;color:var(--muted)}
.empty .ei{font-size:42px;opacity:.5;margin-bottom:10px}

/* mono p/ números/códigos */
.mono,.kpi-value{font-family:var(--font-mono)}

/* ============================================================
 * CLASSES ESPECÍFICAS NEXUS
 * ============================================================ */

/* ── Phase pills (fases 1-5) ─────────────────────────────── */
.phase-pill{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;border-radius:999px;font-size:11px;font-weight:700;white-space:nowrap;border:1px solid transparent;cursor:pointer;transition:.15s}
.phase-pill .pp-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.phase-pill.active{box-shadow:0 0 0 2px var(--brand-dim)}
.phase-pill.p1{background:rgba(245,195,0,.12);color:var(--brand);border-color:rgba(245,195,0,.32)}
.phase-pill.p1 .pp-dot{background:var(--brand)}
.phase-pill.p2{background:rgba(56,189,248,.12);color:#38bdf8;border-color:rgba(56,189,248,.32)}
.phase-pill.p2 .pp-dot{background:#38bdf8}
.phase-pill.p3{background:rgba(167,139,250,.12);color:#a78bfa;border-color:rgba(167,139,250,.32)}
.phase-pill.p3 .pp-dot{background:#a78bfa}
.phase-pill.p4{background:rgba(34,197,94,.12);color:#22c55e;border-color:rgba(34,197,94,.32)}
.phase-pill.p4 .pp-dot{background:#22c55e}
.phase-pill.p5{background:rgba(251,146,60,.12);color:#fb923c;border-color:rgba(251,146,60,.32)}
.phase-pill.p5 .pp-dot{background:#fb923c}

/* ── Dept dot ────────────────────────────────────────────── */
.dept-dot{display:inline-block;width:10px;height:10px;border-radius:50%;flex-shrink:0;vertical-align:middle}
.dept-chip{display:inline-flex;align-items:center;gap:7px;padding:5px 11px;border-radius:9px;font-size:11.5px;font-weight:600;background:var(--surface);border:1px solid var(--border)}

/* ── Trigger item (automações) ───────────────────────────── */
.trigger-item{display:flex;gap:11px;padding:11px 13px;background:var(--surface);border:1px solid var(--border);border-radius:11px;margin-bottom:8px;align-items:flex-start;transition:.14s}
.trigger-item:hover{background:var(--surface2);transform:translateX(2px)}
.trigger-item .trig-dot{width:7px;height:7px;border-radius:50%;margin-top:5px;flex-shrink:0}
.trigger-item .trig-body{flex:1;min-width:0}
.trigger-item .trig-cause{font-size:12px;font-weight:700;color:var(--text)}
.trigger-item .trig-effect{font-size:11.5px;color:var(--muted2);margin-top:2px}

/* ── Field rows (formulário) ─────────────────────────────── */
.field-row,.frow{display:grid;gap:12px;background:linear-gradient(160deg,var(--panel),var(--panel-2));border:1px solid var(--border);border-radius:var(--radius-sm);padding:15px;transition:border-color .15s,background .15s;margin-bottom:11px}
.field-row:hover,.frow:hover{border-color:var(--border2)}
.frow.c1,.field-row.c1{grid-template-columns:1fr}
.frow.c2,.field-row.c2{grid-template-columns:1fr 1fr}
.frow.c3,.field-row.c3{grid-template-columns:1fr 1fr 1fr}
.frow.c4,.field-row.c4{grid-template-columns:1fr 1fr 1fr 1fr}

/* ── Field (label + control) ─────────────────────────────── */
.fld,.fg{display:flex;flex-direction:column;gap:6px}
.fld label,.fl{font-size:11.5px;font-weight:600;color:var(--muted2);display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.fld .req,.fl .req{color:var(--red);font-size:10px}
.fld .fhint,.fhint{font-size:11px;color:var(--muted)}
.ctag{font-family:var(--font-mono);font-size:9px;padding:1px 5px;border-radius:3px}
.ct-cond{background:rgba(56,189,248,.1);color:var(--accent);border:1px solid rgba(56,189,248,.2)}
.ct-auto{background:rgba(34,197,94,.1);color:var(--green);border:1px solid rgba(34,197,94,.2)}
/* inputs internos do form usam .form-control; aliases curtos: */
.fi,.fs,.ft{width:100%;padding:10px 12px;background:var(--surface);border:1px solid var(--border2);border-radius:10px;color:var(--text);font-size:13px;outline:none;transition:.18s}
.fi:focus,.fs:focus,.ft:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-dim)}
.fi::placeholder,.ft::placeholder{color:var(--muted)}
.fi.ok,.fs.ok{border-color:rgba(34,197,94,.4)}
.fs{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%237c8699' stroke-width='1.5' stroke-linecap='round' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 11px center;padding-right:28px}
.fs option{background:#11161f}
[data-theme="light"] .fs option{background:#fff}
.ft{resize:vertical;min-height:64px}

/* ── Dynamic lists ───────────────────────────────────────── */
.dynlist,.dyn{display:flex;flex-direction:column;gap:7px}
.dyn-row{display:grid;gap:8px;align-items:center;background:var(--surface);border:1px solid var(--border);border-radius:9px;padding:9px 11px}
.dyn-row.d3{grid-template-columns:1fr 80px auto}
.dyn-row.d4{grid-template-columns:1fr 1fr 80px auto}
.dyn-row.d5{grid-template-columns:1fr 1fr 1fr 80px auto}
.dyn-row select,.dyn-row input{background:var(--panel);border:1px solid var(--border2);border-radius:8px;padding:7px 9px;font-size:12.5px;color:var(--text);outline:none}
.dyn-row select:focus,.dyn-row input:focus{border-color:var(--brand)}
.btn-rm{width:26px;height:26px;border-radius:7px;cursor:pointer;background:rgba(244,63,94,.12);color:var(--red);font-size:15px;display:flex;align-items:center;justify-content:center;transition:.15s}
.btn-rm:hover{background:rgba(244,63,94,.22)}
.btn-add{display:flex;align-items:center;gap:6px;padding:8px 12px;background:transparent;border:1px dashed var(--border2);border-radius:9px;color:var(--muted);font-size:12.5px;cursor:pointer;transition:.15s;margin-top:4px}
.btn-add:hover{border-color:var(--brand);color:var(--brand)}

/* ── Checkbox group ──────────────────────────────────────── */
.cb-group{display:flex;flex-direction:column;gap:6px}
.cb-item{display:flex;align-items:center;gap:9px;padding:9px 11px;background:var(--surface);border:1px solid var(--border);border-radius:9px;cursor:pointer;transition:.15s}
.cb-item:hover{border-color:var(--border2)}
.cb-item.on{background:var(--brand-dim);border-color:rgba(245,195,0,.35)}
.cb-box{width:16px;height:16px;border-radius:4px;border:1px solid var(--border2);display:flex;align-items:center;justify-content:center;flex-shrink:0;background:var(--panel)}
.cb-item.on .cb-box{background:var(--brand);border-color:var(--brand)}
.cb-chk{font-size:10px;color:var(--brand-ink);display:none}
.cb-item.on .cb-chk{display:block}
.cb-lbl{font-size:12.5px}
.cb-sub{font-size:11px;color:var(--muted)}

/* ── Flags (info/warn/ok/danger) ─────────────────────────── */
.flag{display:flex;gap:11px;padding:11px 13px;border-radius:10px;margin-bottom:8px;align-items:flex-start}
.flag.info{background:rgba(56,189,248,.06);border:1px solid rgba(56,189,248,.22)}
.flag.warn{background:rgba(245,195,0,.06);border:1px solid rgba(245,195,0,.22)}
.flag.ok{background:rgba(34,197,94,.06);border:1px solid rgba(34,197,94,.22)}
.flag.danger{background:rgba(244,63,94,.06);border:1px solid rgba(244,63,94,.22)}
.flag-icon{font-size:15px;flex-shrink:0;margin-top:1px}
.flag-title{font-size:12.5px;font-weight:700;margin-bottom:2px}
.flag-text{font-size:11.5px;color:var(--muted2)}

/* ── Readiness ring ──────────────────────────────────────── */
.readiness-ring{position:relative;width:120px;height:120px;display:flex;align-items:center;justify-content:center}
.readiness-ring svg{transform:rotate(-90deg);width:120px;height:120px}
.readiness-ring .rr-track{fill:none;stroke:var(--surface2);stroke-width:11}
.readiness-ring .rr-fill{fill:none;stroke:var(--brand);stroke-width:11;stroke-linecap:round;transition:stroke-dashoffset .9s cubic-bezier(.4,0,.2,1)}
.readiness-ring .rr-center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.readiness-ring .rr-pct{font-family:var(--font-mono);font-size:26px;font-weight:700;color:var(--text);line-height:1}
.readiness-ring .rr-lbl{font-size:9px;font-weight:800;letter-spacing:.8px;text-transform:uppercase;color:var(--muted);margin-top:3px}

/* ── Pipeline horizontal ─────────────────────────────────── */
.pipe-track{display:flex;align-items:center;gap:0;flex-wrap:wrap}
.pipe-step{display:flex;align-items:center;gap:7px;padding:8px 13px;border-radius:10px;cursor:pointer;transition:.15s;white-space:nowrap;border:1px solid transparent}
.pipe-step:hover{background:var(--surface2)}
.pipe-step.active{background:var(--brand-dim);border-color:rgba(245,195,0,.32)}
.pipe-step.done{background:rgba(34,197,94,.07)}
.pipe-step .pipe-icon{font-size:14px}
.pipe-step .pipe-label{font-size:11px;font-weight:600;color:var(--muted2)}
.pipe-step.active .pipe-label{color:var(--brand);font-weight:700}
.pipe-step.done .pipe-label{color:var(--green)}
.pipe-arrow{color:var(--border2);font-size:11px;padding:0 4px;flex-shrink:0}

/* ── Section nav (anterior / próxima) ────────────────────── */
.sec-nav{display:flex;justify-content:space-between;align-items:center;margin-top:24px;padding-top:16px;border-top:1px solid var(--border)}
.sec-nav .nav-btn{display:flex;align-items:center;gap:6px;font-size:12.5px;font-weight:600;padding:9px 16px;border-radius:10px;cursor:pointer;border:1px solid var(--border2);background:var(--surface);color:var(--text);transition:.15s}
.sec-nav .nav-btn:hover{border-color:var(--brand);color:var(--brand)}
.sec-nav .nav-btn.pr{background:linear-gradient(135deg,var(--brand),var(--brand-2));color:var(--brand-ink);border-color:var(--brand)}
.sec-nav .nav-btn:disabled{opacity:.3;pointer-events:none}

/* ── Overlay mobile ──────────────────────────────────────── */
#sb-overlay{position:fixed;inset:0;background:rgba(5,8,13,.6);z-index:9;opacity:0;pointer-events:none;transition:opacity .25s}
#sb-overlay.show{opacity:1;pointer-events:auto}

/* ── Responsivo ──────────────────────────────────────────── */
@media(max-width:980px){
  .bento{grid-template-columns:repeat(6,1fr)}
  .col-3{grid-column:span 3}.col-4,.col-5{grid-column:span 6}
  .col-6,.col-7,.col-8,.col-9{grid-column:span 6}
  .frow.c3,.frow.c4,.field-row.c3,.field-row.c4{grid-template-columns:1fr 1fr}
}
@media(max-width:600px){
  #sidebar{position:fixed;left:0;top:0;bottom:0;z-index:20;transform:translateX(-100%);box-shadow:0 0 50px rgba(0,0,0,.6)}
  #sidebar.collapsed{width:var(--sidebar-w);min-width:var(--sidebar-w)}
  #sidebar.collapsed .sb-brand,#sidebar.collapsed .nav-label,#sidebar.collapsed .su-info,#sidebar.collapsed .sb-group{opacity:1;width:auto}
  #sidebar-toggle{display:none}
  #sidebar.mobile-open{transform:none}
  .bento{grid-template-columns:1fr}
  .col-3,.col-4,.col-5,.col-6,.col-7,.col-8,.col-9{grid-column:span 1}
  .page{padding:18px 15px 60px}
  .topbar{padding:14px 16px}
  .topbar-title{font-size:16px}
  .frow.c2,.frow.c3,.frow.c4,.field-row.c2,.field-row.c3,.field-row.c4{grid-template-columns:1fr}
}

/* ════════════════════════════════════════════════════════════
 * COMPAT — Classes da lógica de domínio portada do v6.
 * Estilizadas no padrão Command. Não remover.
 * ════════════════════════════════════════════════════════════ */

/* ── Shell extras (mountShell) ── */
.sb-logo{padding:20px 18px 14px;display:flex;flex-direction:column;gap:2px}
.logo-mark{font-family:var(--font-display);font-size:22px;font-weight:800;color:var(--brand);letter-spacing:-.5px;line-height:1}
.logo-tag{font-size:9px;font-weight:700;letter-spacing:1.6px;text-transform:uppercase;color:var(--muted)}
.sb-user{display:flex;align-items:center;gap:10px;padding:6px;border-radius:12px;background:var(--surface);flex:1;min-width:0}
.user-avatar{width:34px;height:34px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:800;color:var(--brand-ink);background:linear-gradient(140deg,var(--brand),#e0a000);flex-shrink:0}
.user-info{min-width:0;flex:1}
.user-name{font-size:12.5px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.user-role{font-size:10px;color:var(--muted);text-transform:capitalize}
.btn-logout{padding:7px 12px;border-radius:9px;background:var(--surface);border:1px solid var(--border);color:var(--muted2);font-size:11px;font-weight:700;transition:.16s}
.btn-logout:hover{color:var(--red);border-color:rgba(244,63,94,.4);background:rgba(244,63,94,.1)}
.sb-footer{padding:12px;border-top:1px solid var(--border);display:flex;align-items:center;gap:8px}
.save-dot{width:8px;height:8px;border-radius:50%;background:var(--green);flex-shrink:0;transition:background .3s}
.save-dot.busy{background:var(--amber)}
.topbar-left{flex:1;min-width:0}
#topbar-actions{display:flex;align-items:center;gap:9px}

/* ── Project selector na sidebar ── */
.proj-sel{display:flex;align-items:center;gap:8px;padding:9px 11px;margin:0 12px;border-radius:11px;background:var(--surface);border:1px solid var(--border);cursor:pointer;transition:.16s}
.proj-sel:hover{border-color:var(--brand);background:var(--brand-dim)}
.proj-sel-name{flex:1;font-size:12.5px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text)}
.proj-sel-caret{font-size:10px;color:var(--muted)}
.proj-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.proj-dd{margin:6px 12px 0;background:var(--panel-2);border:1px solid var(--border2);border-radius:12px;overflow:hidden;box-shadow:var(--shadow)}
.pd-item{display:flex;align-items:center;gap:9px;padding:10px 12px;cursor:pointer;transition:.12s;border-bottom:1px solid var(--border)}
.pd-item:hover{background:var(--surface2)}
.pd-item.active{background:var(--brand-dim)}
.pd-name{flex:1;font-size:12.5px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pd-meta{font-size:9px;font-family:var(--font-mono);color:var(--muted);text-transform:uppercase;letter-spacing:.4px}
.pd-new{padding:10px 12px;color:var(--brand);font-size:12px;font-weight:700;cursor:pointer}
.pd-new:hover{background:var(--brand-dim)}

/* ── Section header (form) ── */
.sec-hdr{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:14px}
.sec-hdr-num{font-family:var(--font-mono);font-size:10px;font-weight:700;letter-spacing:.3px}
.sec-hdr-title{font-family:var(--font-display);font-size:21px;font-weight:800;letter-spacing:-.4px;color:var(--text)}
.sec-hdr-sub{font-size:11px;color:var(--muted);margin-top:3px}
.sec-pct{font-family:var(--font-mono);font-size:24px;font-weight:700;line-height:1}
.sec-pct-lbl{font-family:var(--font-mono);font-size:10px;color:var(--muted);text-align:right;margin-top:2px}
.dept-banner{display:flex;align-items:center;gap:8px;padding:9px 14px;border-radius:11px;font-size:12.5px;margin-bottom:16px}
.dept-banner strong{font-weight:700}
.dept-banner span{color:var(--muted2)}

/* ── Form grid + fields ── */
.fgrid{display:flex;flex-direction:column;gap:11px}
.frow{display:grid;gap:14px;background:var(--surface);border:1px solid var(--border);border-radius:13px;padding:16px}
.frow.c1{grid-template-columns:1fr}
.frow.c2{grid-template-columns:1fr 1fr}
.frow.c3{grid-template-columns:1fr 1fr 1fr}
.frow.c4{grid-template-columns:1fr 1fr 1fr 1fr}
.fg{display:flex;flex-direction:column;gap:7px;min-width:0}
.fl{font-size:10.5px;font-weight:800;text-transform:uppercase;letter-spacing:.6px;color:var(--muted);display:flex;align-items:center;gap:5px;flex-wrap:wrap}
.req{color:var(--red);font-size:12px}
.fi,.fs,.ft{width:100%;padding:10px 12px;background:var(--bg2);border:1px solid var(--border2);border-radius:10px;color:var(--text);font-size:13px;font-family:inherit;outline:none;transition:.16s}
.fi:focus,.fs:focus,.ft:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-dim)}
.fi::placeholder,.ft::placeholder{color:var(--muted)}
.fi.ok,.fs.ok{border-color:rgba(34,197,94,.4)}
.fs{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%237c8699' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 11px center;padding-right:28px}
.fs option{background:var(--panel)}
.ft{resize:vertical;min-height:64px}
.fhint{font-size:11px;color:var(--muted);line-height:1.4}

/* ── Checkbox group ── */
.cb-group{display:flex;flex-direction:column;gap:6px}
.cb-item{display:flex;align-items:flex-start;gap:9px;padding:9px 11px;background:var(--bg2);border:1px solid var(--border);border-radius:10px;cursor:pointer;transition:.15s}
.cb-item:hover{border-color:var(--border2)}
.cb-item.on{background:var(--brand-dim);border-color:rgba(245,195,0,.4)}
.cb-box{width:16px;height:16px;border-radius:5px;border:1.5px solid var(--border2);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px;transition:.15s}
.cb-item.on .cb-box{background:var(--brand);border-color:var(--brand)}
.cb-chk{font-size:10px;color:var(--brand-ink);opacity:0;font-weight:900}
.cb-item.on .cb-chk{opacity:1}
.cb-lbl{font-size:13px;font-weight:600;color:var(--text)}
.cb-sub{font-size:11px;color:var(--muted);margin-top:1px}

/* ── Flags (inline alerts) ── */
.flag{display:flex;gap:10px;align-items:flex-start;padding:11px 13px;border-radius:11px;margin-bottom:9px;border:1px solid var(--border)}
.flag.info{background:rgba(56,189,248,.08);border-color:rgba(56,189,248,.25)}
.flag.ok{background:rgba(34,197,94,.08);border-color:rgba(34,197,94,.25)}
.flag.warn{background:rgba(245,158,11,.08);border-color:rgba(245,158,11,.25)}
.flag.danger{background:rgba(244,63,94,.08);border-color:rgba(244,63,94,.25)}
.flag-icon{font-size:16px;flex-shrink:0}
.flag-title{font-size:12.5px;font-weight:700;margin-bottom:2px}
.flag-text{font-size:11.5px;color:var(--muted2);line-height:1.5}
.ft-c{color:var(--blue)}.ft-g{color:var(--green)}.ft-y{color:var(--amber)}.ft-r{color:var(--red)}

/* ── Section nav (anterior/próxima) ── */
.sec-nav{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:18px;padding-top:16px;border-top:1px solid var(--border)}
.nav-btn{padding:10px 18px;border-radius:11px;background:var(--surface);border:1px solid var(--border2);color:var(--muted2);font-size:12.5px;font-weight:700;transition:.16s}
.nav-btn:hover:not(:disabled){border-color:var(--brand);color:var(--brand)}
.nav-btn:disabled{opacity:.35;cursor:not-allowed}
.nav-btn.pr{background:linear-gradient(135deg,var(--brand),var(--brand-2));color:var(--brand-ink);border:none}

/* ── Dept cards (painel direito) ── */
.dept-card{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:11px;background:var(--surface);border:1px solid var(--border);cursor:pointer;transition:.15s;margin-bottom:7px}
.dept-card:hover{transform:translateX(3px);border-color:var(--brand)}
.dc-icon{font-size:18px;flex-shrink:0;width:34px;height:34px;display:flex;align-items:center;justify-content:center;border-radius:9px;background:var(--surface2)}
.dc-info{flex:1;min-width:0}
.dc-name{font-size:12.5px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dc-sub{font-size:10px;color:var(--muted);font-family:var(--font-mono)}
.dc-badge{font-size:10px;font-weight:800;padding:3px 9px;border-radius:999px;white-space:nowrap;font-family:var(--font-mono)}
.dc-ok{background:rgba(34,197,94,.15);color:var(--green)}
.dc-pend{background:rgba(245,195,0,.15);color:var(--brand)}
.dc-wait{background:var(--surface2);color:var(--muted)}

/* ── Triggers ── */
.trigger{display:flex;gap:9px;align-items:flex-start;padding:9px 0;border-bottom:1px solid var(--border)}
.trigger:last-child{border-bottom:none}
.trig-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;margin-top:5px}
.trig-body{flex:1;min-width:0}
.trig-cause{font-size:12px;font-weight:700;color:var(--text)}
.trig-effect{font-size:11px;color:var(--muted2);margin-top:2px}

/* ── Activity log ── */
.act-item{display:flex;gap:9px;align-items:flex-start;padding:7px 0;border-bottom:1px solid var(--border)}
.act-item:last-child{border-bottom:none}
.act-dot{width:6px;height:6px;border-radius:50%;background:var(--brand);flex-shrink:0;margin-top:5px}
.act-text{flex:1;font-size:11.5px;color:var(--muted2)}
.act-time{font-size:9.5px;font-family:var(--font-mono);color:var(--muted);flex-shrink:0}

/* ── Buttons (compat tb-btn) ── */
.tb-btn{padding:9px 16px;border-radius:10px;font-size:12.5px;font-weight:700;transition:.16s;border:1px solid transparent}
.tb-btn.primary{background:linear-gradient(135deg,var(--brand),var(--brand-2));color:var(--brand-ink);box-shadow:0 8px 20px -8px rgba(245,195,0,.6)}
.tb-btn.primary:hover{transform:translateY(-1px)}
.tb-btn.secondary{background:var(--surface);border-color:var(--border2);color:var(--muted2)}
.tb-btn.secondary:hover{color:var(--text);border-color:var(--brand)}

/* ── Modal (compat) ── */
.modal-bg{position:fixed;inset:0;background:rgba(5,8,13,.72);backdrop-filter:blur(6px);display:none;align-items:center;justify-content:center;z-index:1000;padding:20px}
.modal-bg.open{display:flex;animation:rise .25s ease}
.modal-bg .modal{background:linear-gradient(160deg,var(--panel),var(--panel-2));border:1px solid var(--border2);border-radius:18px;width:100%;max-width:440px;padding:24px;box-shadow:0 30px 80px rgba(0,0,0,.6)}
.modal-title{font-family:var(--font-display);font-size:17px;font-weight:800;margin-bottom:18px}
.modal-row{margin-bottom:13px}
.modal-label{font-size:10.5px;font-weight:800;text-transform:uppercase;letter-spacing:.6px;color:var(--muted);margin-bottom:7px}
.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}

/* ── Command palette (compat) ── */
.cmd-overlay{position:fixed;inset:0;background:rgba(5,8,13,.74);backdrop-filter:blur(6px);display:none;align-items:flex-start;justify-content:center;z-index:2000;padding-top:12vh}
.cmd-overlay.open{display:flex}
.cmd-box{width:100%;max-width:600px;background:linear-gradient(160deg,var(--panel),var(--panel-2));border:1px solid var(--border2);border-radius:16px;overflow:hidden;box-shadow:0 40px 90px rgba(0,0,0,.7)}
.cmd-input{width:100%;padding:18px 22px;background:transparent;border:none;border-bottom:1px solid var(--border);color:var(--text);font-size:16px;outline:none;font-family:inherit}
.cmd-input::placeholder{color:var(--muted)}
.cmd-results{max-height:52vh;overflow-y:auto;padding:8px}
.cmd-item{display:flex;align-items:center;gap:12px;padding:11px 15px;border-radius:11px;cursor:pointer}
.cmd-item.sel,.cmd-item:hover{background:var(--brand-dim)}
.cmd-ico{width:22px;text-align:center;font-size:15px}
.cmd-label{flex:1;font-size:14px;font-weight:600}
.cmd-sub{font-size:11px;color:var(--muted)}

/* ── Toast (compat host) ── */
#toast-host{position:fixed;bottom:24px;right:24px;z-index:9999;display:flex;flex-direction:column;gap:10px}
.toast{background:var(--panel-2);border:1px solid var(--border2);border-left:3px solid var(--blue);border-radius:12px;padding:13px 17px;font-size:13px;color:var(--text);box-shadow:var(--shadow);opacity:0;transform:translateX(40px);transition:.32s;max-width:340px}
.toast.show{opacity:1;transform:none}
.toast.success{border-left-color:var(--green)}
.toast.warn{border-left-color:var(--amber)}
.toast.error{border-left-color:var(--red)}
.toast.info{border-left-color:var(--blue)}

/* ── Dynamic lists (devices, caixas, pbl) ── */
.dynlist{display:flex;flex-direction:column;gap:8px}
.dyn-row{display:flex;gap:8px;align-items:center}
.dyn-row .fi,.dyn-row .fs{flex:1}
.btn-add{padding:8px 14px;border-radius:10px;background:var(--surface);border:1px dashed var(--border2);color:var(--muted2);font-size:12px;font-weight:700;transition:.16s;align-self:flex-start}
.btn-add:hover{border-color:var(--brand);color:var(--brand)}
.btn-del{width:34px;height:34px;border-radius:9px;background:rgba(244,63,94,.1);color:var(--red);font-size:16px;flex-shrink:0;transition:.15s}
.btn-del:hover{background:rgba(244,63,94,.2)}

/* ── Pipeline horizontal (form header) ── */
.dot{width:8px;height:8px;border-radius:50%;display:inline-block}

/* ── Pulse de etapa ativa (pipeline value-stream) ── */
@keyframes nx-pulse-orange{0%,100%{box-shadow:0 0 0 rgba(245,158,11,0)}50%{box-shadow:0 0 14px rgba(245,158,11,.45)}}
.nx-pulse-orange{animation:nx-pulse-orange 2.4s ease-in-out infinite}
@media(prefers-reduced-motion:reduce){.nx-pulse-orange,.sb-next-arrow{animation:none}}
