/* ============================================================
   Controle Cismetro - Tema Dark
   ============================================================ */

:root{
  --bg:        #0d1117;
  --surface:   #161b22;
  --surface-2: #21262d;
  --border:    #30363d;
  --border-2:  #484f58;
  --text:      #e6edf3;
  --text-2:    #8b949e;
  --muted:     #6e7681;
  --accent:    #3b82f6;
  --accent-bg: #1a2f4a;
  --accent-br: #2563eb;
  --success:   #22c55e;
  --success-bg:#14532d;
  --warn:      #f59e0b;
  --warn-bg:   #3d2108;
  --danger:    #ef4444;
  --danger-bg: #3d0e0e;
  --mono:'JetBrains Mono','Consolas',monospace;
  --sans:'Inter','-apple-system',Segoe UI,sans-serif;
  --radius:8px;
  --shadow:    0 1px 3px rgba(0,0,0,.4);
  --shadow-lg: 0 4px 16px rgba(0,0,0,.5);
}

*{margin:0;padding:0;box-sizing:border-box}
html,body{height:100%}
body{font-family:var(--sans);background:var(--bg);color:var(--text);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;text-transform:uppercase}

a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}

/* ---- Header ------------------------------------------------ */
.app-hdr{
  background:var(--surface);
  border-bottom:1px solid var(--border);
  padding:14px 32px;
  display:flex;align-items:center;justify-content:space-between;
  position:sticky;top:0;z-index:50;
}
.app-hdr-title{font-weight:700;font-size:15px;letter-spacing:-.2px;color:var(--text)}
.app-hdr-sub{font-size:11px;color:var(--muted);font-family:var(--mono)}
.nav{display:flex;gap:4px}
.nav a{padding:7px 14px;border-radius:6px;font-size:13px;font-weight:500;color:var(--text-2);transition:.15s}
.nav a:hover{background:var(--surface-2);text-decoration:none;color:var(--text)}
.nav a.active{background:var(--accent-bg);color:var(--accent)}

/* ---- Container --------------------------------------------- */
.container{max-width:1280px;margin:0 auto;padding:28px 32px}
.page-title{font-size:22px;font-weight:700;margin-bottom:4px;letter-spacing:-.4px}
.page-sub{color:var(--text-2);font-size:13px;margin-bottom:24px}

/* ---- Cards ------------------------------------------------- */
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow)}
.card-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--muted);margin-bottom:14px;font-family:var(--mono)}
.grid-3{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;margin-bottom:22px}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:18px}

/* ---- KPI --------------------------------------------------- */
.kpi{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px 18px}
.kpi-label{font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.8px;color:var(--muted);margin-bottom:6px}
.kpi-value{font-size:22px;font-weight:700;color:var(--text);line-height:1.1}
.kpi-sub{font-size:11px;color:var(--text-2);margin-top:4px;font-family:var(--mono)}

/* ---- Buttons ----------------------------------------------- */
.btn{display:inline-flex;align-items:center;gap:6px;padding:9px 16px;font-family:var(--sans);font-size:13px;font-weight:500;background:var(--surface-2);color:var(--text);border:1px solid var(--border-2);border-radius:6px;cursor:pointer;transition:.15s;text-decoration:none}
.btn:hover{background:var(--border);text-decoration:none}
.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}
.btn-primary:hover{background:#2563eb;color:#fff}
.btn-success{background:#166534;color:#dcfce7;border-color:#166534}
.btn-success:hover{background:#14532d;color:#dcfce7}
.btn-danger{background:var(--danger-bg);color:var(--danger);border-color:var(--danger)}
.btn-danger:hover{background:#7f1d1d;color:#fca5a5}
.btn-sm{padding:6px 10px;font-size:12px}
.btn-icon{padding:7px 9px}
.btn[disabled]{opacity:.4;cursor:not-allowed}

/* ---- Forms ------------------------------------------------- */
.input,.select{width:100%;padding:9px 12px;background:var(--surface-2);border:1px solid var(--border-2);border-radius:6px;font-family:var(--sans);font-size:13px;color:var(--text);transition:.15s}
.input:focus,.select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(59,130,246,.2)}
.input::placeholder{color:var(--muted)}
label{font-size:12px;font-weight:500;color:var(--text-2);display:block;margin-bottom:6px}
select option{background:var(--surface-2);color:var(--text)}

/* ---- Table ------------------------------------------------- */
.tbl{width:100%;border-collapse:collapse;font-size:13px}
.tbl thead th{background:var(--surface-2);padding:10px 12px;text-align:left;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.8px;color:var(--muted);border-bottom:1px solid var(--border);font-family:var(--mono);position:sticky;top:0;z-index:1}
.tbl tbody td{padding:10px 12px;border-bottom:1px solid var(--border);vertical-align:middle;color:var(--text)}
.tbl tbody tr:hover{background:var(--surface-2)}
.tbl tbody tr.selected{background:var(--accent-bg)}
.tbl .tr{text-align:right}
.tbl .tm{font-family:var(--mono);font-size:12px}
.tbl-wrap{overflow-x:auto;max-height:600px;overflow-y:auto;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface)}

/* ---- Badge ------------------------------------------------- */
.badge{display:inline-block;padding:3px 8px;border-radius:4px;font-size:11px;font-weight:500;font-family:var(--mono);letter-spacing:.3px;border:1px solid}
.badge-neutral{background:var(--surface-2);color:var(--text-2);border-color:var(--border)}
.badge-accent{background:var(--accent-bg);color:var(--accent);border-color:var(--accent-br)}
.badge-success{background:var(--success-bg);color:var(--success);border-color:#166534}
.badge-warn{background:var(--warn-bg);color:var(--warn);border-color:#78350f}
.badge-danger{background:var(--danger-bg);color:var(--danger);border-color:#7f1d1d}

/* ---- Dropzone ---------------------------------------------- */
.dropzone{border:2px dashed var(--border-2);border-radius:var(--radius);padding:60px 24px;text-align:center;background:var(--surface);transition:.2s;cursor:pointer}
.dropzone:hover,.dropzone.drag{border-color:var(--accent);background:var(--accent-bg)}
.dropzone-title{font-size:16px;font-weight:600;margin-bottom:6px;color:var(--text)}
.dropzone-sub{font-size:13px;color:var(--text-2)}
.dropzone input[type=file]{display:none}

/* ---- Alerts ------------------------------------------------ */
.alert{padding:12px 16px;border-radius:6px;border:1px solid;font-size:13px;margin-bottom:14px}
.alert-info{background:var(--accent-bg);border-color:var(--accent-br);color:#93c5fd}
.alert-success{background:var(--success-bg);border-color:#166534;color:#86efac}
.alert-warn{background:var(--warn-bg);border-color:#78350f;color:#fcd34d}
.alert-danger{background:var(--danger-bg);border-color:#7f1d1d;color:#fca5a5}

/* ---- Toolbar ----------------------------------------------- */
.toolbar{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:16px}
.toolbar .input,.toolbar .select{width:auto;min-width:200px}

/* ---- Checkbox ---------------------------------------------- */
input[type=checkbox]{width:15px;height:15px;accent-color:var(--accent);cursor:pointer}

/* ---- Bulk bar ---------------------------------------------- */
.bulk-bar{position:sticky;bottom:0;background:var(--surface);border:1px solid var(--border);border-top:2px solid var(--accent);padding:12px 16px;border-radius:var(--radius);margin-top:12px;display:flex;gap:10px;align-items:center;box-shadow:var(--shadow-lg)}
.bulk-count{font-weight:600;font-size:13px;color:var(--accent)}

/* ---- Helpers ----------------------------------------------- */
.text-mt{color:var(--muted)}
.text-t2{color:var(--text-2)}
.mono{font-family:var(--mono)}

/* ---- Scrollbar --------------------------------------------- */
::-webkit-scrollbar{width:8px;height:8px}
::-webkit-scrollbar-track{background:var(--surface)}
::-webkit-scrollbar-thumb{background:var(--border-2);border-radius:4px}
::-webkit-scrollbar-thumb:hover{background:var(--muted)}

@media(max-width:900px){
  .grid-2{grid-template-columns:1fr}
  .container{padding:20px 16px}
  .app-hdr{padding:12px 16px}
}
