/* ============================================================
   Sofit Next — App styles (shell + componentes reutilizáveis)
   ============================================================ */
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{margin:0;background:var(--bg);color:var(--ink);font-family:var(--sans);font-size:14.5px;line-height:1.55;-webkit-font-smoothing:antialiased}
a{color:var(--brand);text-decoration:none}
h1,h2,h3,h4{margin:0;line-height:1.2;letter-spacing:-.02em}
.muted{color:var(--ink-2)} .mono{font-family:var(--mono)} .small{font-size:12.5px}
.eyebrow{font-size:11.5px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--brand)}

/* ---------- shell ---------- */
.shell{display:grid;grid-template-columns:var(--sidebar) 1fr;min-height:100vh}
.sidebar{background:var(--surface);border-right:1px solid var(--line);display:flex;flex-direction:column;
  position:sticky;top:0;height:100vh;overflow-y:auto}
.sb-brand{display:flex;align-items:center;gap:10px;height:60px;padding:0 18px;font-weight:750;letter-spacing:-.02em;border-bottom:1px solid var(--line)}
.logo{width:30px;height:30px;border-radius:8px;background:linear-gradient(135deg,var(--brand),var(--brand-2));
  display:grid;place-items:center;color:#fff;font-weight:800;box-shadow:var(--shadow-sm)}
.brand-mark{width:30px;height:30px;object-fit:contain;display:block;flex:0 0 auto}
.brand-mark-lg{width:48px;height:48px;object-fit:contain;display:block;margin-bottom:16px}
.sb-nav{padding:12px 10px;flex:1}
.sb-group{font-size:10.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);padding:14px 12px 6px}
.sb-link{display:flex;align-items:center;gap:11px;padding:9px 12px;border-radius:var(--r-sm);color:var(--ink-2);font-weight:500;margin:1px 0}
.sb-link:hover{background:var(--surface-2);color:var(--ink)}
.sb-link.active{background:var(--brand-soft);color:var(--brand);font-weight:650}
.sb-link .ic{width:20px;text-align:center;font-size:15px}

/* ---------- topbar ---------- */
.main{display:flex;flex-direction:column;min-width:0}
.topbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;gap:14px;height:60px;padding:0 22px;
  background:color-mix(in srgb,var(--bg) 85%,transparent);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.search{flex:1;max-width:440px;display:flex;align-items:center;gap:9px;background:var(--surface-2);
  border:1px solid var(--line);border-radius:999px;padding:8px 14px;color:var(--ink-3)}
.search input{border:0;background:transparent;outline:0;color:var(--ink);font:inherit;width:100%}
.usermenu{margin-left:auto;display:flex;align-items:center;gap:10px}
.avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--brand),var(--brand-2));
  color:#fff;display:grid;place-items:center;font-weight:700;font-size:13px}
.hamb{display:none;background:transparent;border:1px solid var(--line);border-radius:8px;width:36px;height:36px;color:var(--ink);font-size:17px;cursor:pointer}
.content{padding:26px 22px 60px}
.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:22px;flex-wrap:wrap}
.page-head h1{font-size:25px;font-weight:800}

/* ---------- grid ---------- */
.grid{display:grid;gap:16px}
.cols-4{grid-template-columns:repeat(4,1fr)} .cols-3{grid-template-columns:repeat(3,1fr)} .cols-2{grid-template-columns:repeat(2,1fr)}
@media(max-width:1024px){.cols-4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:720px){.cols-4,.cols-3,.cols-2{grid-template-columns:1fr}}

/* ---------- card / kpi ---------- */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:18px;box-shadow:var(--shadow)}
.card h3{font-size:13px;font-weight:650;color:var(--ink-2);text-transform:uppercase;letter-spacing:.05em;margin-bottom:14px}
.kpi .ic{width:36px;height:36px;border-radius:10px;background:var(--brand-soft);color:var(--brand);display:grid;place-items:center;font-size:18px;margin-bottom:13px}
.kpi .v{font-size:28px;font-weight:800;letter-spacing:-.03em;line-height:1}
.kpi .l{color:var(--ink-2);font-size:13px;margin-top:6px}
.kpi .s{color:var(--ink-3);font-size:12px;margin-top:2px}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:8px;font:inherit;font-weight:600;font-size:13.5px;cursor:pointer;
  border:1px solid var(--line);background:var(--surface);color:var(--ink);padding:9px 15px;border-radius:var(--r-sm);transition:.12s}
.btn:hover{background:var(--surface-2)}
.btn-primary{background:var(--brand);border-color:var(--brand);color:#fff}
.btn-primary:hover{filter:brightness(1.07);background:var(--brand)}
.btn-ghost{background:transparent}
.btn-sm{padding:6px 11px;font-size:12.5px}

/* ---------- badges ---------- */
.badge{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:650;padding:3px 10px;border-radius:999px;border:1px solid var(--line);text-transform:capitalize}
.badge.ativo,.badge.ok{color:var(--ok);background:var(--ok-soft);border-color:transparent}
.badge.manutencao,.badge.warn{color:var(--warn);background:var(--warn-soft);border-color:transparent}
.badge.inativo,.badge.bad{color:var(--bad);background:var(--bad-soft);border-color:transparent}
.badge.info{color:var(--info);background:var(--info-soft);border-color:transparent}

/* ---------- forms ---------- */
.field{margin-bottom:14px}
.field label{display:block;font-size:12.5px;font-weight:600;color:var(--ink-2);margin-bottom:6px}
.input{width:100%;font:inherit;color:var(--ink);background:var(--surface);border:1px solid var(--line);border-radius:var(--r-sm);padding:11px 13px;outline:0;transition:.12s}
.input:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-soft)}

/* ---------- alerts ---------- */
.alert{padding:11px 14px;border-radius:var(--r-sm);font-size:13px;margin-bottom:14px;border:1px solid transparent}
.alert.bad{color:var(--bad);background:var(--bad-soft)}
.alert.info{color:var(--info);background:var(--info-soft)}
.alert.warn{color:var(--warn);background:var(--warn-soft)}

/* ---------- table (usado por <sx-datatable>) ---------- */
table.tbl{width:100%;border-collapse:collapse;font-size:13.5px}
.tbl th,.tbl td{text-align:left;padding:11px 14px;border-bottom:1px solid var(--line)}
.tbl th{color:var(--ink-3);font-weight:650;font-size:11px;text-transform:uppercase;letter-spacing:.05em;cursor:pointer;user-select:none}
.tbl th:hover{color:var(--ink)}
.tbl tbody tr:hover{background:var(--surface-2)}
.tbl td.num{text-align:right;font-variant-numeric:tabular-nums;font-family:var(--mono);font-size:12.5px}

/* ---------- auth ---------- */
.auth-wrap{position:relative;overflow:hidden;min-height:100vh;display:grid;place-items:center;padding:24px;
  background:radial-gradient(900px 500px at 70% -10%,var(--brand-soft),transparent),var(--bg)}
.auth-card{position:relative;z-index:1;width:100%;max-width:380px;background:var(--surface);border:1px solid var(--line);
  border-radius:18px;padding:30px;box-shadow:var(--shadow)}
.auth-card .logo{width:42px;height:42px;border-radius:12px;font-size:20px;margin-bottom:18px}

/* ---------- misc ---------- */
.pill{display:inline-flex;align-items:center;gap:7px;background:var(--brand-soft);color:var(--brand);
  border:1px solid color-mix(in srgb,var(--brand) 22%,transparent);padding:5px 11px;border-radius:999px;font-size:12px;font-weight:650}
.dot{width:7px;height:7px;border-radius:50%;background:var(--ok)}
.toolbar{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:14px}
.spacer{flex:1}

/* ---------- responsive sidebar ---------- */
@media(max-width:900px){
  .shell{grid-template-columns:1fr}
  .sidebar{position:fixed;left:0;top:0;width:var(--sidebar);transform:translateX(-100%);transition:.22s;z-index:50}
  .shell.open .sidebar{transform:none;box-shadow:var(--shadow)}
  .shell.open::after{content:"";position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:40}
  .hamb{display:grid;place-items:center}
}

/* ---------- modal CRUD ---------- */
.sx-modal{position:fixed;inset:0;background:rgba(0,0,0,.55);display:none;place-items:center;z-index:100;padding:20px;backdrop-filter:blur(2px)}
.sx-modal.open{display:grid}
.sx-modal .box{background:var(--surface);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);width:100%;max-width:520px;max-height:90vh;overflow:auto;padding:22px}
.tbl td.act{text-align:right;white-space:nowrap}
.tbl td.act .btn{padding:4px 9px;margin-left:5px}
