/* =========================
   FACTORY EYE · OS — Theme
   Coloque em /static/os-theme.css
   ========================= */
:root{
  /* Marca */
  --brand: #ec1c85;
  --brand-dark: #c21565;
  --brand-light: #f94ca6;

  /* Neutros */
  --ink:#0f172a;
  --muted:#64748b;
  --muted-2:#94a3b8;
  --line:#e2e8f0;
  --bg:#f1f5f9;
  --card:#ffffff;

  /* Estados */
  --ok:#22c55e;
  --ok-dark:#15803d;
  --info:#06b6d4;
  --info-dark:#0e7490;
  --warn:#f59e0b;
  --danger:#ef4444;
  --danger-dark:#b91c1c;

  /* Raios / sombras */
  --r-s:10px; --r-m:12px; --r-l:16px; --r-xl:18px;
  --shadow-1: 0 12px 28px rgba(236,28,133,.20);
  --shadow-2: 0 25px 60px rgba(0,0,0,.25);
}

/* Base */
* { box-sizing:border-box }
html,body { height:100% }
body {
  margin:0;
  background: var(--bg);
  color: var(--ink);
  font-family: ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  line-height:1.35;
}

/* Layout containers */
.wrap { max-width: 1200px; margin: 22px auto; padding: 0 16px; }
.small { max-width: 420px; margin: 0 auto; }

/* Topbar (gradiente) */
.top {
  background: linear-gradient(135deg, var(--brand-light), var(--brand));
  color:#fff;
  padding: 16px 18px;
  display:flex; align-items:center; justify-content:space-between;
  box-shadow: 0 10px 24px rgba(236,28,133,.25);
}
.top .brand { display:flex; align-items:center; gap:10px; font-weight:800 }
.top .brand img { height:36px; width:auto }
.top .nav a {
  color:#fff; text-decoration:none; margin-left: 10px;
  padding:8px 12px; border-radius:12px; background: rgba(255,255,255,.14);
}
.top .nav a:hover { background: rgba(255,255,255,.18); }

/* Cards, grids */
.card {
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: var(--r-l);
  padding: 16px;
  box-shadow: 0 3px 10px rgba(2,6,23,.04);
  margin-bottom: 14px;
}
.grid { display:grid; gap: 14px; }
.grid.auto { grid-template-columns: repeat(auto-fit, minmax(220px,1fr)); }

/* Tipografia utilitária */
.h1 { font-size: 22px; font-weight: 800; color: var(--ink); margin: 0 0 6px; }
.muted { color: var(--muted); }
.badge, .pill {
  display:inline-block; padding:6px 10px; border-radius:999px; font-size:12px;
  background:#eaeef6; color: var(--ink);
}

/* Botões */
.btn {
  display:inline-block;
  padding:12px 14px;
  border-radius:12px;
  text-decoration:none;
  color:#fff;
  background: linear-gradient(180deg, var(--brand), var(--brand-dark));
  box-shadow: var(--shadow-1);
  border:0; cursor:pointer; font-weight:700;
}
.btn:hover { filter: brightness(1.03); }
.btn:active { transform: translateY(1px); }

.btn-ghost {
  background: transparent; color: var(--ink);
  border: 1px solid var(--line); box-shadow:none;
}
.btn-info { background: linear-gradient(180deg, var(--info), var(--info-dark)); color:#fff; }
.btn-ok   { background: linear-gradient(180deg, var(--ok),   var(--ok-dark));   color:#fff; }
.btn-danger{background: linear-gradient(180deg, var(--danger), var(--danger-dark)); color:#fff;}

/* Inputs & forms */
label { display:block; font-size:12px; color:#475569; margin:8px 2px 4px; }
input, select, textarea {
  width: 100%; padding: 11px 12px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: #fff;
  font-size: 14px; outline: none;
}
textarea { min-height: 96px; }
input:focus, select:focus, textarea:focus {
  border-color: var(--brand);
  box-shadow: 0 0 0 4px rgba(236,28,133,.15);
  background: #fff;
}

/* Tabelas */
table { width:100%; border-collapse:collapse; }
th, td { padding: 10px; border-bottom: 1px solid var(--line); font-size: 14px; }
th { text-align:left; color:#475569; font-weight:600; }
.table-actions form { display:inline-block; margin-right:6px; }

/* Chips de filtro */
.chips a{
  display:inline-block; padding:8px 10px; border-radius:999px;
  background:#fff; border:1px solid var(--line);
  text-decoration:none; color: var(--ink); margin: 0 8px 8px 0;
}
.chips a.active{
  background: linear-gradient(180deg, var(--brand), var(--brand-dark));
  color:#fff; border-color: transparent;
}

/* Alertas */
.alert { border-radius:12px; padding:10px 12px; font-size:14px; }
.alert-error { color:#b91c1c; background:#fee2e2; border:1px solid #fecaca; }
.alert-warn  { color:#92400e; background:#fef3c7; border:1px solid #fde68a; }
.alert-ok    { color:#065f46; background:#d1fae5; border:1px solid #a7f3d0; }

/* Login específico (centralizado) */
.login-bg {
  min-height: 100vh; display:flex; align-items:center; justify-content:center;
  background: linear-gradient(135deg, var(--brand-light) 0%, var(--brand) 50%, var(--brand-dark) 100%);
}
.login-card {
  background:#fff; padding: 32px 28px; border-radius: var(--r-xl);
  width: 100%; max-width: 380px; box-shadow: var(--shadow-2); text-align:center;
}
.login-card .brand { display:flex; align-items:center; justify-content:center; margin-bottom: 14px; }
.login-card .brand img { height:70px; width:auto; }
.login-card h1 { margin:8px 0 2px; font-size:22px; color:var(--ink); font-weight:700; }
.login-card h2 { margin:0 0 18px; font-size:13px; font-weight:500; color: var(--muted-2); }

/* Responsivo */
@media (max-width: 720px){
  .grid.col-3, .row-3 { grid-template-columns: 1fr !important; }
  .top .nav a { margin-left:6px; padding:7px 10px; }
}

/* “Botões” rápidos reutilizáveis para status */
.btn-andamento { background: linear-gradient(180deg, var(--info), var(--info-dark)); color:#fff; }
.btn-fechar    { background: linear-gradient(180deg, var(--ok),   var(--ok-dark));  color:#fff; }

/* --- compact helpers --- */
.btn-sm{ padding:6px 10px; font-size:13px; border-radius:10px }
.input-sm{ height:36px; padding:8px 10px; font-size:14px; border-radius:10px }
.select-sm{ height:36px; padding:6px 10px; font-size:14px; border-radius:10px }
.compact-grid{ display:grid; grid-template-columns: 1fr 1fr auto; gap:8px; align-items:end }
.actions-row{ display:flex; gap:8px; flex-wrap:wrap; align-items:center }
.actions-row .btn{ box-shadow:none } /* menos destaque visual */
1~/* --- compact helpers --- */
.btn-sm{ padding:6px 10px; font-size:13px; border-radius:10px }
.input-sm{ height:36px; padding:8px 10px; font-size:14px; border-radius:10px }
.select-sm{ height:36px; padding:6px 10px; font-size:14px; border-radius:10px }
.compact-grid{ display:grid; grid-template-columns: 1fr 1fr auto; gap:8px; align-items:end }
.actions-row{ display:flex; gap:8px; flex-wrap:wrap; align-items:center }
.actions-row .btn{ box-shadow:none } /* menos destaque visual */
1~/* --- compact helpers --- */
.btn-sm{ padding:6px 10px; font-size:13px; border-radius:10px }
.input-sm{ height:36px; padding:8px 10px; font-size:14px; border-radius:10px }
.select-sm{ height:36px; padding:6px 10px; font-size:14px; border-radius:10px }
.compact-grid{ display:grid; grid-template-columns: 1fr 1fr auto; gap:8px; align-items:end }
.actions-row{ display:flex; gap:8px; flex-wrap:wrap; align-items:center }
.actions-row .btn{ box-shadow:none } /* menos destaque visual */
