
@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&family=JetBrains+Mono:wght@400;500&display=swap');

:root{
  --bg:#f0f2f8;
  --surface:#ffffff;
  --border:#e2e8f0;
  --border-strong:#cbd5e1;
  --text:#0f172a;
  --muted:#64748b;
  --hint:#94a3b8;

  /* Azul principal vibrante */
  --blue:#2563e8;
  --blue-bg:#eff6ff;
  --blue-t:#1e40af;
  --blue-light:#dbeafe;

  /* Verde vivo */
  --green:#059669;
  --green-bg:#ecfdf5;
  --green-t:#065f46;
  --green-light:#a7f3d0;

  /* Vermelho */
  --red:#dc2626;
  --red-bg:#fef2f2;
  --red-t:#991b1b;

  /* Âmbar */
  --amber:#d97706;
  --amber-bg:#fffbeb;
  --amber-t:#92400e;
  --amber-light:#fde68a;

  /* Roxo */
  --purple:#7c3aed;
  --purple-bg:#f5f3ff;
  --purple-t:#5b21b6;
  --purple-light:#ddd6fe;

  /* Ciano/Teal */
  --teal:#0891b2;
  --teal-bg:#ecfeff;
  --teal-t:#164e63;

  /* Rosa */
  --pink:#db2777;
  --pink-bg:#fdf2f8;
  --pink-t:#831843;

  --gray-bg:#f8fafc;
  --gray-t:#475569;

  --r:10px;
  --r-sm:7px;
  --r-lg:14px;
  --sh:0 1px 3px rgba(15,23,42,.06),0 1px 2px rgba(15,23,42,.04);
  --sh-md:0 4px 6px -1px rgba(15,23,42,.07),0 2px 4px -1px rgba(15,23,42,.04);
  --sh-lg:0 10px 15px -3px rgba(15,23,42,.08),0 4px 6px -2px rgba(15,23,42,.04);
  --sh-xl:0 20px 25px -5px rgba(15,23,42,.10),0 10px 10px -5px rgba(15,23,42,.04);

  /* Sidebar */
  --sb-bg:#0f172a;
  --sb-bg2:#1e293b;
  --sb-bg-hover:rgba(255,255,255,0.07);
  --sb-bg-active:rgba(37,99,232,0.25);
  --sb-border:rgba(255,255,255,0.06);
  --sb-text:rgba(255,255,255,0.55);
  --sb-text-active:#fff;
  --sb-text-muted:rgba(255,255,255,0.3);
  --sb-accent:#3b82f6;
}

*{box-sizing:border-box;margin:0;padding:0}
body{
  font-family:'Plus Jakarta Sans',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  font-size:14px;line-height:1.5;
  background:var(--bg);color:var(--text);min-height:100vh;
  -webkit-font-smoothing:antialiased;
}
code,pre,.font-mono{font-family:'JetBrains Mono','Fira Code',monospace;font-size:12px}

::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:9999px}
::-webkit-scrollbar-thumb:hover{background:#94a3b8}

/* ── Scrollbar larga e facil de usar no Kanban ── */
#kanban-board::-webkit-scrollbar{width:10px;height:14px}
#kanban-board::-webkit-scrollbar-track{background:#dde1e7;border-radius:8px;margin:0 12px}
#kanban-board::-webkit-scrollbar-thumb{background:#94a3b8;border-radius:8px;border:2px solid #dde1e7;min-width:60px}
#kanban-board::-webkit-scrollbar-thumb:hover{background:#475569}
#kanban-board::-webkit-scrollbar-thumb:active{background:#1e3a8a}
#kanban-board::-webkit-scrollbar-corner{background:#dde1e7}

/* ═══════════════════════════════════════
   SIDEBAR
═══════════════════════════════════════ */
.sidebar{
  position:fixed;top:0;left:0;bottom:0;width:224px;
  background:var(--sb-bg);
  border-right:1px solid var(--sb-border);
  display:flex;flex-direction:column;
  z-index:100;
  box-shadow:4px 0 24px rgba(0,0,0,.15);
}
.sidebar-header{
  display:flex;align-items:center;gap:11px;
  padding:18px 16px;
  border-bottom:1px solid var(--sb-border);
  background:linear-gradient(135deg,rgba(37,99,232,.15),transparent);
}
.sidebar-logo{
  width:34px;height:34px;border-radius:9px;
  background:linear-gradient(135deg,#2563e8,#7c3aed);
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-weight:800;font-size:15px;flex-shrink:0;
  box-shadow:0 4px 12px rgba(37,99,232,.4);
}
.sidebar-title{color:#fff;font-size:13px;font-weight:700;line-height:1.1;letter-spacing:-.01em}
.sidebar-subtitle{color:var(--sb-text-muted);font-size:10px;margin-top:2px;font-weight:500}

.sidebar-nav{flex:1;overflow-y:auto;padding:10px 8px}
.sidebar-section{
  color:var(--sb-text-muted);
  font-size:9.5px;font-weight:700;
  text-transform:uppercase;letter-spacing:0.1em;
  padding:18px 10px 6px;
}
.nav-btn{
  display:flex;align-items:center;gap:10px;
  width:100%;padding:9px 12px;
  font-size:13px;font-weight:500;
  color:var(--sb-text);
  background:transparent;border:none;border-radius:8px;
  cursor:pointer;font-family:inherit;text-align:left;
  transition:all .18s ease;
  margin-bottom:1px;position:relative;
}
.nav-btn .nav-icon{opacity:.6;flex-shrink:0;font-size:15px}
.nav-btn:hover{background:var(--sb-bg-hover);color:rgba(255,255,255,.88)}
.nav-btn:hover .nav-icon{opacity:.9}
.nav-btn.active{
  background:var(--sb-bg-active);
  color:var(--sb-text-active);font-weight:600;
}
.nav-btn.active::before{
  content:'';position:absolute;left:0;top:20%;bottom:20%;
  width:3px;background:var(--sb-accent);border-radius:0 3px 3px 0;
}
.nav-btn.active .nav-icon{opacity:1}

.sidebar-footer{border-top:1px solid var(--sb-border);padding:12px 8px}
.sidebar-user{display:flex;align-items:center;gap:10px;margin-bottom:8px;padding:8px;border-radius:8px;background:rgba(255,255,255,.04)}
.sidebar-avatar{
  width:30px;height:30px;border-radius:50%;
  background:linear-gradient(135deg,#2563e8,#7c3aed);
  color:#fff;font-size:11px;font-weight:700;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.sidebar-user-info{flex:1;min-width:0}
.sidebar-user-email{color:rgba(255,255,255,.82);font-size:11px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sidebar-user-role{color:rgba(255,255,255,.32);font-size:10px;margin-top:1px}
.btn-logout{
  width:100%;display:flex;align-items:center;gap:8px;
  padding:7px 12px;font-size:11px;font-weight:500;
  color:rgba(255,255,255,.4);
  background:transparent;border:none;border-radius:7px;
  cursor:pointer;font-family:inherit;transition:all .15s;
}
.btn-logout:hover{background:rgba(239,68,68,.15);color:#fca5a5}

.sidebar-proj-sel{margin:0 8px 8px}
.sidebar-proj-sel select{
  width:100%;font-size:11px;padding:7px 10px;
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.1);
  border-radius:7px;color:#fff;outline:none;
  font-family:inherit;
}
.sidebar-proj-sel select option{background:var(--sb-bg);color:#fff}

.status-indicator{
  display:flex;align-items:center;gap:6px;
  padding:6px 12px;margin-bottom:6px;
  font-size:10.5px;color:var(--sb-text-muted);font-weight:500;
}
.sdot{width:7px;height:7px;border-radius:50%;background:#475569;flex-shrink:0}
.sdot.ok{background:#10b981;box-shadow:0 0 6px rgba(16,185,129,.5)}
.sdot.err{background:#ef4444;box-shadow:0 0 6px rgba(239,68,68,.5)}

/* ═══════════════════════════════════════
   MAIN CONTENT
═══════════════════════════════════════ */
.main-wrap{
  margin-left:224px;min-height:100vh;
  background:var(--bg);
  background-image:
    radial-gradient(ellipse at 20% 0%,rgba(37,99,232,.06) 0%,transparent 50%),
    radial-gradient(ellipse at 80% 100%,rgba(124,58,237,.05) 0%,transparent 50%);
}
.screen{display:none;padding:28px 36px;max-width:1360px;margin:0 auto}
.screen.active{display:block}

@media(max-width:768px){
  .sidebar{width:64px}
  .sidebar-title,.sidebar-subtitle,.nav-btn span,.sidebar-section,
  .sidebar-user-info,.btn-logout span,.sidebar-proj-sel,.status-indicator{display:none}
  .nav-btn{justify-content:center;padding:10px;border-radius:8px}
  .nav-btn.active::before{display:none}
  .btn-logout{justify-content:center}
  .main-wrap{margin-left:64px}
  .screen{padding:16px}
}

/* ═══════════════════════════════════════
   CARDS
═══════════════════════════════════════ */
.card{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  padding:22px 24px;margin-bottom:18px;
  box-shadow:var(--sh-md);
  transition:box-shadow .2s ease,transform .2s ease;
}
.card:hover{box-shadow:var(--sh-lg)}
.card-title{font-size:14px;font-weight:700;margin-bottom:3px;color:var(--text);letter-spacing:-.01em}
.card-sub{font-size:11.5px;color:var(--muted);margin-bottom:14px;font-weight:500}

/* ═══════════════════════════════════════
   BADGES
═══════════════════════════════════════ */
.badge{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;padding:3px 10px;border-radius:20px;letter-spacing:.01em}
.bg{background:var(--green-bg);color:var(--green-t);border:1px solid var(--green-light)}
.bb{background:var(--blue-bg);color:var(--blue-t);border:1px solid var(--blue-light)}
.bgr{background:var(--gray-bg);color:var(--gray-t);border:1px solid var(--border)}
.br{background:var(--red-bg);color:var(--red-t);border:1px solid #fecaca}
.ba{background:var(--amber-bg);color:var(--amber-t);border:1px solid var(--amber-light)}
.bp{background:var(--purple-bg);color:var(--purple-t);border:1px solid var(--purple-light)}

/* ═══════════════════════════════════════
   METRICS
═══════════════════════════════════════ */
.metric-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:14px;margin-bottom:18px}
.metric{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  padding:16px 18px;
  box-shadow:var(--sh);
  transition:transform .2s,box-shadow .2s;
  position:relative;overflow:hidden;
}
.metric::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--blue),var(--purple));
  border-radius:var(--r-lg) var(--r-lg) 0 0;
}
.metric:hover{transform:translateY(-2px);box-shadow:var(--sh-md)}
.ml{font-size:11px;color:var(--muted);margin-bottom:8px;font-weight:600;text-transform:uppercase;letter-spacing:.04em}
.mv{font-size:26px;font-weight:800;line-height:1;letter-spacing:-0.03em;color:var(--text)}

/* ═══════════════════════════════════════
   GRIDS
═══════════════════════════════════════ */
.two{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:18px}
.three{display:grid;grid-template-columns:1fr 1fr 1fr;gap:18px;margin-bottom:18px}
.four{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:14px;margin-bottom:18px}
@media(max-width:900px){.three{grid-template-columns:1fr 1fr}}
@media(max-width:700px){.two,.three,.four{grid-template-columns:1fr}}

/* ═══════════════════════════════════════
   PROGRESS BARS
═══════════════════════════════════════ */
.pbar{height:8px;background:var(--border);border-radius:9999px;overflow:hidden;margin-top:8px}
.pfill{height:100%;background:linear-gradient(90deg,var(--blue),var(--purple));border-radius:9999px;transition:width .5s cubic-bezier(.4,0,.2,1)}

/* ═══════════════════════════════════════
   TREE (EAP)
═══════════════════════════════════════ */
.tree-item{border-bottom:1px solid var(--border)}
.tree-item:last-child{border-bottom:none}
.tree-row{
  display:flex;align-items:center;gap:8px;
  padding:10px 6px;cursor:pointer;user-select:none;
  border-radius:var(--r-sm);transition:background .12s;
}
.tree-row:hover{background:var(--blue-bg);padding-left:10px}
.tree-kids{padding-left:22px;display:none}
.tree-kids.open{display:block}
.chev{font-size:10px;color:var(--hint);display:inline-block;width:12px;transition:transform .15s}
.chev.open{transform:rotate(90deg)}
.rr{margin-left:auto;display:flex;align-items:center;gap:12px;font-size:11px;color:var(--muted)}

/* ═══════════════════════════════════════
   INPUTS & FORMS
═══════════════════════════════════════ */
input,select,textarea{
  font-size:13px;padding:9px 13px;
  border:1.5px solid var(--border);border-radius:var(--r-sm);
  background:var(--surface);color:var(--text);
  width:100%;outline:none;font-family:inherit;
  transition:border-color .15s,box-shadow .15s;
  font-weight:500;
}
input:focus,select:focus,textarea:focus{
  border-color:var(--blue);
  box-shadow:0 0 0 3px rgba(37,99,232,.12);
}
input::placeholder{color:var(--hint);font-weight:400}

/* ═══════════════════════════════════════
   BUTTONS
═══════════════════════════════════════ */
.btn{
  font-size:13px;font-weight:600;
  padding:8px 18px;border-radius:var(--r-sm);
  border:1.5px solid var(--border);
  background:var(--surface);color:var(--text);
  cursor:pointer;font-family:inherit;
  transition:all .15s ease;
  display:inline-flex;align-items:center;gap:6px;
  letter-spacing:-.01em;
}
.btn:hover{background:var(--gray-bg);border-color:var(--border-strong);transform:translateY(-1px);box-shadow:var(--sh)}
.btn:active{transform:translateY(0)}
.btn-p{
  background:linear-gradient(135deg,var(--blue),#4f46e5);
  color:#fff;border-color:transparent;
  box-shadow:0 4px 12px rgba(37,99,232,.3);
}
.btn-p:hover{background:linear-gradient(135deg,var(--blue-t),#4338ca);border-color:transparent;box-shadow:0 6px 16px rgba(37,99,232,.4)}
.btn-sm{font-size:11px;padding:5px 12px;border-radius:6px}
.btn-success{background:linear-gradient(135deg,var(--green),#10b981);color:#fff;border-color:transparent;box-shadow:0 4px 12px rgba(5,150,105,.3)}
.btn-success:hover{box-shadow:0 6px 16px rgba(5,150,105,.4)}
.btn-danger{background:linear-gradient(135deg,var(--red),#ef4444);color:#fff;border-color:transparent;box-shadow:0 4px 12px rgba(220,38,38,.25)}

.lnk{color:var(--blue);font-size:12px;cursor:pointer;background:none;border:none;padding:0;font-family:inherit;font-weight:600}
.lnk:hover{text-decoration:underline;color:var(--blue-t)}

/* ═══════════════════════════════════════
   LOADING / SPIN
═══════════════════════════════════════ */
.loading{text-align:center;padding:4rem;color:var(--muted)}
.spin{
  width:28px;height:28px;
  border:3px solid var(--border);
  border-top-color:var(--blue);
  border-radius:50%;
  animation:sp .65s linear infinite;
  margin:0 auto 12px;
}
@keyframes sp{to{transform:rotate(360deg)}}

/* ═══════════════════════════════════════
   MESSAGES
═══════════════════════════════════════ */
.msg{border-radius:var(--r-sm);padding:11px 15px;font-size:12px;margin-top:10px;font-weight:500;border-left:3px solid}
.me{background:var(--red-bg);color:var(--red-t);border-left-color:var(--red)}
.mo{background:var(--green-bg);color:var(--green-t);border-left-color:var(--green)}

/* ═══════════════════════════════════════
   SECTION HEAD
═══════════════════════════════════════ */
.flow{display:none}.flow.active{display:block}
.login-wrap{max-width:440px;margin:4rem auto}

.filter-bar{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;margin-bottom:18px}
.section-head{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;gap:16px;flex-wrap:wrap}
.section-head h2{font-size:22px;font-weight:800;letter-spacing:-0.03em;color:var(--text)}
.section-head p{font-size:12px;color:var(--muted);margin-top:3px;font-weight:500}

/* ═══════════════════════════════════════
   ALERT CARDS
═══════════════════════════════════════ */
.alert-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(175px,1fr));gap:14px}
.acrd{
  background:var(--surface);border:1.5px solid var(--border);
  border-radius:var(--r-lg);padding:18px;cursor:pointer;
  transition:all .2s ease;box-shadow:var(--sh);
  position:relative;overflow:hidden;
}
.acrd::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,transparent,var(--blue),transparent);
  opacity:0;transition:opacity .2s;
}
.acrd:hover{border-color:var(--blue);box-shadow:var(--sh-md);transform:translateY(-2px)}
.acrd:hover::after{opacity:1}
.alb{font-size:12px;font-weight:700;margin-bottom:3px;letter-spacing:-.01em}
.als{font-size:11px;color:var(--muted);margin-bottom:12px;font-weight:500}
.aln{font-size:32px;font-weight:800;line-height:1;letter-spacing:-0.04em}

/* ═══════════════════════════════════════
   GANTT / ROADMAP
═══════════════════════════════════════ */
.gantt-wrap{overflow-x:auto;margin-top:.75rem;border-radius:var(--r-sm);border:1px solid var(--border)}
.gantt-table{border-collapse:collapse;font-size:11px;min-width:600px;width:100%}
.gantt-table th{padding:7px 10px;background:var(--gray-bg);border:1px solid var(--border);font-weight:700;white-space:nowrap;font-size:10.5px;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}
.gantt-table td{padding:5px 10px;border:1px solid var(--border);white-space:nowrap}
.gantt-table tr:nth-child(even) td{background:#fafbfc}
.gantt-bar{height:14px;background:linear-gradient(90deg,var(--blue),#6366f1);border-radius:4px}
.gantt-bar.gantt-bar-yellow{background:linear-gradient(90deg,#facc15,#f59e0b)}
.gantt-done{background:linear-gradient(90deg,var(--green),#10b981)}

/* ═══════════════════════════════════════
   DONUT / LEGEND
═══════════════════════════════════════ */
.donut-wrap{display:flex;align-items:center;gap:1.75rem}
.dleg{font-size:11px}
.dleg div{display:flex;align-items:center;gap:7px;margin-bottom:6px;font-weight:500}
.ddot{width:10px;height:10px;border-radius:50%;flex-shrink:0}

/* ═══════════════════════════════════════
   PRINT BAR
═══════════════════════════════════════ */
.print-bar{display:flex;align-items:center;gap:10px;margin-bottom:1.25rem;font-size:12px;color:var(--muted);font-weight:500}

/* ═══════════════════════════════════════
   STATUS REPORT FRASES
═══════════════════════════════════════ */
.sr-help-frase{
  font-size:12px;line-height:1.75;padding:10px 14px;
  background:var(--gray-bg);border:1.5px solid var(--border);
  border-radius:var(--r-sm);margin-bottom:7px;cursor:pointer;
  color:var(--text);transition:all .15s;font-weight:500;
}
.sr-help-frase:hover{border-color:var(--blue);background:var(--blue-bg);color:var(--blue-t);transform:translateX(4px)}

/* ═══════════════════════════════════════
   TOGGLE
═══════════════════════════════════════ */
.toggle{position:relative;display:inline-block;width:44px;height:24px}
.toggle input{opacity:0;width:0;height:0}
.tslider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background:#cbd5e1;border-radius:24px;transition:.3s}
.tslider:before{position:absolute;content:"";height:18px;width:18px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:.3s;box-shadow:0 1px 3px rgba(0,0,0,.2)}
.toggle input:checked + .tslider{background:linear-gradient(135deg,var(--blue),#6366f1)}
.toggle input:checked + .tslider:before{transform:translateX(20px)}

/* ═══════════════════════════════════════
   MODALS
═══════════════════════════════════════ */
.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(15,23,42,.5);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;animation:fadeIn .15s ease}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.modal-box{background:var(--surface);border-radius:var(--r-lg);border:1px solid var(--border);padding:28px;width:100%;max-width:560px;max-height:90vh;overflow-y:auto;box-shadow:var(--sh-xl);animation:slideUp .2s cubic-bezier(.4,0,.2,1)}
@keyframes slideUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--border)}
.modal-title{font-size:17px;font-weight:800;letter-spacing:-0.02em}
.modal-close{background:none;border:none;font-size:22px;cursor:pointer;color:var(--muted);line-height:1;padding:4px;border-radius:6px;transition:all .15s}
.modal-close:hover{color:var(--text);background:var(--gray-bg)}
.modal-field{margin-bottom:16px}
.modal-field label{display:block;font-size:11px;font-weight:700;color:var(--muted);margin-bottom:5px;text-transform:uppercase;letter-spacing:.04em}
.modal-2col{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.modal-footer{display:flex;gap:10px;justify-content:flex-end;margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--border)}
.modal-msg{font-size:12px;padding:11px 15px;border-radius:var(--r-sm);margin-top:12px;font-weight:500;border-left:3px solid}
.modal-msg.ok{background:var(--green-bg);color:var(--green-t);border-left-color:var(--green)}
.modal-msg.err{background:var(--red-bg);color:var(--red-t);border-left-color:var(--red)}

.edit-btn{font-size:11px;padding:3px 10px;border-radius:6px;border:1.5px solid var(--border);background:transparent;color:var(--blue);cursor:pointer;margin-left:6px;white-space:nowrap;transition:all .15s;font-weight:600}
.edit-btn:hover{background:var(--blue-bg);border-color:var(--blue);transform:translateY(-1px)}

/* ═══════════════════════════════════════
   LOGIN SCREEN
═══════════════════════════════════════ */
body.login-mode .sidebar{display:none}
body.login-mode .main-wrap{
  margin-left:0;
  background:linear-gradient(135deg,#0f172a 0%,#1e1b4b 40%,#1e3a5f 100%);
  min-height:100vh;
  display:flex;align-items:center;justify-content:center;
}
body.login-mode .screen{
  background:transparent;
  padding:0;
  max-width:100%;
}
body.login-mode .login-wrap{
  background:rgba(255,255,255,.97);
  border-radius:20px;
  padding:40px 44px;
  box-shadow:0 32px 64px rgba(0,0,0,.4);
  max-width:420px;
  width:calc(100vw - 48px);
  margin:0 auto;
}
body.login-mode .card{box-shadow:none;border:none;padding:0;margin:0;background:transparent}

/* ═══════════════════════════════════════
   TABLE MODERN
═══════════════════════════════════════ */
table.tbl{width:100%;border-collapse:collapse;font-size:13px}
table.tbl thead tr{background:var(--gray-bg);border-bottom:2px solid var(--border)}
table.tbl thead th{padding:10px 14px;font-size:10.5px;font-weight:700;color:var(--muted);text-align:left;text-transform:uppercase;letter-spacing:.05em}
table.tbl tbody tr{border-bottom:1px solid var(--border);transition:background .1s}
table.tbl tbody tr:hover{background:#f8faff}
table.tbl tbody td{padding:11px 14px}

/* ═══════════════════════════════════════
   CHIP TABS
═══════════════════════════════════════ */
.chip-tabs{display:flex;gap:4px;background:var(--gray-bg);padding:4px;border-radius:10px;border:1px solid var(--border);margin-bottom:18px}
.chip-tab{font-size:12px;font-weight:600;padding:6px 14px;border-radius:7px;border:none;background:transparent;color:var(--muted);cursor:pointer;font-family:inherit;transition:all .15s;white-space:nowrap}
.chip-tab:hover{color:var(--text);background:rgba(255,255,255,.7)}
.chip-tab.active{background:var(--surface);color:var(--blue);box-shadow:var(--sh);border:1px solid var(--border)}

/* ═══════════════════════════════════════
   STATUS COLOR CODING
═══════════════════════════════════════ */
.status-pill{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;padding:3px 10px;border-radius:20px}
.status-pill::before{content:'';width:6px;height:6px;border-radius:50%;background:currentColor;flex-shrink:0}
.sp-green{background:var(--green-bg);color:var(--green-t)}
.sp-blue{background:var(--blue-bg);color:var(--blue-t)}
.sp-red{background:var(--red-bg);color:var(--red-t)}
.sp-amber{background:var(--amber-bg);color:var(--amber-t)}
.sp-gray{background:var(--gray-bg);color:var(--gray-t)}
.sp-purple{background:var(--purple-bg);color:var(--purple-t)}

/* ═══════════════════════════════════════
   ANÁLISE IA BOX
═══════════════════════════════════════ */
.ai-box{
  margin-top:16px;padding:16px 18px;
  background:linear-gradient(135deg,#faf5ff,#eff6ff);
  border:1.5px solid #ddd6fe;border-radius:var(--r);
  font-size:12px;line-height:1.75;color:var(--text);
}
.ai-box-header{
  display:flex;align-items:center;gap:7px;
  margin-bottom:12px;font-weight:700;
  color:var(--purple-t);font-size:12px;
}

/* ═══════════════════════════════════════
   MODERN PAGE HEADERS — colorido e informal
═══════════════════════════════════════ */

/* Cabeçalho de página padrão modernizado */
.page-header{
  display:flex;align-items:flex-start;justify-content:space-between;
  margin-bottom:28px;flex-wrap:wrap;gap:16px;
}
.page-header-left{display:flex;align-items:center;gap:16px}
.page-header-icon{
  width:52px;height:52px;border-radius:16px;
  display:flex;align-items:center;justify-content:center;
  font-size:24px;flex-shrink:0;
  box-shadow:0 4px 12px rgba(0,0,0,.1);
}
.page-header-icon.coral{background:linear-gradient(135deg,#ff6b6b,#ee5a24)}
.page-header-icon.teal{background:linear-gradient(135deg,#00d2d3,#0abde3)}
.page-header-icon.violet{background:linear-gradient(135deg,#a55eea,#8854d0)}
.page-header-icon.amber{background:linear-gradient(135deg,#ffd32a,#f9ca24)}
.page-header-icon.emerald{background:linear-gradient(135deg,#26de81,#20bf6b)}
.page-header-icon.indigo{background:linear-gradient(135deg,#4a69bd,#6a89cc)}
.page-header-icon.rose{background:linear-gradient(135deg,#fd79a8,#e84393)}
.page-header-icon.blue{background:linear-gradient(135deg,#2563e8,#4f46e5)}

.page-header h2{
  font-size:24px;font-weight:800;
  letter-spacing:-0.03em;color:var(--text);
  line-height:1.1;
}
.page-header p{font-size:13px;color:var(--muted);margin-top:4px;font-weight:500}
.page-header-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}

/* Faixa decorativa colorida no topo de cada tela */
#andamento.screen::before,
#acomp.screen::before,
#sr.screen::before,
#hist.screen::before,
#cad.screen::before,
#import.screen::before{
  content:'';display:block;
  height:4px;border-radius:2px;
  margin-bottom:28px;
}
#andamento.screen::before{background:linear-gradient(90deg,#ff6b6b,#ffd32a,#26de81)}
#acomp.screen::before{background:linear-gradient(90deg,#00d2d3,#0abde3,#4a69bd)}
#sr.screen::before{background:linear-gradient(90deg,#a55eea,#fd79a8,#ee5a24)}
#hist.screen::before{background:linear-gradient(90deg,#26de81,#0abde3,#a55eea)}
#cad.screen::before{background:linear-gradient(90deg,#4a69bd,#2563e8,#a55eea)}
#import.screen::before{background:linear-gradient(90deg,#ffd32a,#ee5a24,#fd79a8)}

/* Cards com bordas coloridas por contexto */
#andamento .card:first-of-type{border-top:3px solid #ff6b6b}
#acomp .card:first-of-type{border-top:3px solid #00d2d3}
#sr .card:first-of-type{border-top:3px solid #a55eea}
#hist .card:first-of-type{border-top:3px solid #26de81}

/* Seção de header melhorada para section-head existente */
.section-head h2{
  font-size:22px !important;font-weight:800 !important;
  letter-spacing:-0.03em !important;
}

/* Tags de contexto coloridas */
.ctx-tag{
  display:inline-flex;align-items:center;gap:5px;
  font-size:10px;font-weight:700;
  padding:3px 10px;border-radius:20px;
  text-transform:uppercase;letter-spacing:.05em;
}
.ctx-tag.editing{background:#fff3cd;color:#856404;border:1px solid #ffc107}
.ctx-tag.tracking{background:#cff4fc;color:#0c5460;border:1px solid #0dcaf0}
.ctx-tag.reporting{background:#f3d9fa;color:#6f2fa0;border:1px solid #c678dd}
.ctx-tag.history{background:#d1f7e7;color:#0d6e3e;border:1px solid #20bf6b}

/* Barra de filtros moderna */
.filter-bar-modern{
  display:flex;align-items:center;gap:10px;
  padding:14px 18px;
  background:linear-gradient(135deg,var(--gray-bg),#f0f4ff);
  border:1.5px solid var(--border);
  border-radius:var(--r-lg);
  margin-bottom:18px;
  flex-wrap:wrap;
}
.filter-bar-modern label{
  display:flex;align-items:center;gap:6px;
  font-size:12px;font-weight:600;cursor:pointer;
  padding:5px 12px;border-radius:20px;
  border:1.5px solid transparent;
  transition:all .15s;color:var(--muted);
  background:var(--surface);
}
.filter-bar-modern label:has(input:checked){
  border-color:var(--blue);color:var(--blue-t);
  background:var(--blue-bg);
}
.filter-bar-modern input[type=checkbox]{
  width:14px;height:14px;flex-shrink:0;accent-color:var(--blue);
}

/* Histórico timeline */
.timeline-item{
  display:flex;gap:14px;
  padding:14px 0;
  border-bottom:1px solid var(--border);
  position:relative;
}
.timeline-dot{
  width:10px;height:10px;border-radius:50%;
  background:var(--blue);flex-shrink:0;
  margin-top:5px;
  box-shadow:0 0 0 3px rgba(37,99,232,.15);
}
.timeline-dot.green{background:var(--green);box-shadow:0 0 0 3px rgba(22,163,74,.15)}
.timeline-dot.amber{background:var(--amber);box-shadow:0 0 0 3px rgba(234,179,8,.15)}
.timeline-dot.red{background:var(--red);box-shadow:0 0 0 3px rgba(239,68,68,.15)}

/* Chips de abas coloridas */
.tab-chips{display:flex;gap:6px;margin-bottom:20px;flex-wrap:wrap}
.tab-chip{
  padding:7px 18px;border-radius:20px;
  font-size:12px;font-weight:700;
  border:2px solid transparent;
  cursor:pointer;font-family:inherit;
  transition:all .18s;background:var(--gray-bg);
  color:var(--muted);
}
.tab-chip:hover{transform:translateY(-1px);box-shadow:var(--sh)}
.tab-chip.active-coral{background:#fff0f0;color:#c0392b;border-color:#ff6b6b}
.tab-chip.active-teal{background:#e0fafa;color:#0c7a7a;border-color:#00d2d3}
.tab-chip.active-violet{background:#f5effe;color:#7b2fbe;border-color:#a55eea}
.tab-chip.active-blue{background:var(--blue-bg);color:var(--blue-t);border-color:var(--blue)}
.tab-chip.active-emerald{background:#e8fdf2;color:#0d6e3e;border-color:#26de81}
.tab-chip.active-amber{background:#fffbeb;color:#92400e;border-color:#ffd32a}

/* Empty state amigável */
.empty-state{
  text-align:center;padding:48px 24px;color:var(--muted);
}
.empty-state-icon{font-size:48px;margin-bottom:12px;opacity:.6}
.empty-state h3{font-size:16px;font-weight:700;color:var(--text);margin-bottom:6px}
.empty-state p{font-size:13px;line-height:1.6}

/* Highlight box informativo */
.info-box{
  padding:14px 18px;border-radius:var(--r-sm);
  font-size:12px;line-height:1.7;font-weight:500;
  display:flex;align-items:flex-start;gap:10px;
}
.info-box.blue{background:var(--blue-bg);border-left:3px solid var(--blue);color:var(--blue-t)}
.info-box.green{background:var(--green-bg);border-left:3px solid var(--green);color:var(--green-t)}
.info-box.amber{background:var(--amber-bg);border-left:3px solid #f59e0b;color:var(--amber-t)}
.info-box.purple{background:var(--purple-bg);border-left:3px solid var(--purple);color:var(--purple-t)}
.info-box.red{background:var(--red-bg);border-left:3px solid var(--red);color:var(--red-t)}
