/* HotMinds Brand CSS — generato da .impeccable.md */

/* ── Font self-host ── */
@font-face { font-family:"Cabinet Grotesk"; src:url("../fonts/cabinet-grotesk-700.woff2") format("woff2"); font-weight:700; font-display:swap; }
@font-face { font-family:"Cabinet Grotesk"; src:url("../fonts/cabinet-grotesk-500.woff2") format("woff2"); font-weight:500; font-display:swap; }
@font-face { font-family:"Satoshi"; src:url("../fonts/satoshi-400.woff2") format("woff2"); font-weight:400; font-display:swap; }
@font-face { font-family:"Satoshi"; src:url("../fonts/satoshi-500.woff2") format("woff2"); font-weight:500; font-display:swap; }
@font-face { font-family:"Satoshi"; src:url("../fonts/satoshi-700.woff2") format("woff2"); font-weight:700; font-display:swap; }
@font-face { font-family:"Satoshi"; src:url("../fonts/satoshi-900.woff2") format("woff2"); font-weight:900; font-display:swap; }
@font-face { font-family:"JetBrains Mono"; src:url("../fonts/jetbrains-mono-400.woff2") format("woff2"); font-weight:400; font-display:swap; }
@font-face { font-family:"JetBrains Mono"; src:url("../fonts/jetbrains-mono-500.woff2") format("woff2"); font-weight:500; font-display:swap; }

/* ── Token dark (default) ── */
:root {
  --lime: #BFDD2E;
  --lime-ink: #0B1304;
  --purple: #6C5CE7;
  --ink: #0A0A0F;
  --paper: #F4F4EE;
  --ink-soft: #9097A8;
  --paper-soft: #4B4F5A;
  --ok: #3FA34D;
  --warn: #E0A12B;
  --error: #D6453A;
  --info: #6C5CE7;

  --bg: var(--ink);
  --fg: #F4F4EE;
  --muted: var(--ink-soft);
  --surface: #13131A;
  --border: #22222E;

  --bs-body-bg: var(--bg);
  --bs-body-color: var(--fg);
  --bs-primary: #BFDD2E;
  --bs-primary-rgb: 191, 221, 46;
  --bs-font-sans-serif: "Satoshi", system-ui, sans-serif;
  --bs-font-monospace: "JetBrains Mono", ui-monospace, monospace;
  --bs-border-color: var(--border);
  --bs-card-bg: var(--surface);
  --bs-card-border-color: var(--border);
  --bs-table-bg: transparent;
  --bs-table-striped-bg: rgba(255,255,255,0.03);
  --bs-table-hover-bg: rgba(191,221,46,0.06);
  --bs-table-border-color: var(--border);
}

/* ── Token light ── */
[data-bs-theme="light"] {
  --bg: var(--paper);
  --fg: #0A0A0F;
  --muted: var(--paper-soft);
  --surface: #FFFFFF;
  --border: #E2E2D8;

  --bs-body-bg: var(--bg);
  --bs-body-color: var(--fg);
  --bs-border-color: var(--border);
  --bs-card-bg: var(--surface);
  --bs-card-border-color: var(--border);
  --bs-table-hover-bg: rgba(191,221,46,0.08);
  --bs-table-border-color: var(--border);
}

/* ── Base ── */
body {
  background: var(--bg);
  color: var(--fg);
  font-family: var(--bs-font-sans-serif);
  font-size: 15px;
  line-height: 24px;
}

h1, h2, h3, .display {
  font-family: "Cabinet Grotesk", "SF Pro Display", "Helvetica Neue", sans-serif;
  letter-spacing: -0.02em;
}

code, pre, .font-mono, td code {
  font-family: "JetBrains Mono", ui-monospace, monospace;
  font-size: 13px;
}

/* ── Navbar ── */
.navbar-hm {
  background: var(--ink) !important;
  border-bottom: 1px solid var(--border);
  padding-top: 0.6rem;
  padding-bottom: 0.6rem;
}
[data-bs-theme="light"] .navbar-hm {
  background: var(--surface) !important;
  border-bottom: 1px solid var(--border);
}
.navbar-hm .navbar-brand {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  color: var(--fg);
  font-family: "Cabinet Grotesk", sans-serif;
  font-weight: 700;
  font-size: 1rem;
}
.navbar-hm .logo-img {
  height: 26px;
  filter: invert(1);                    /* dark default: SVG nero → bianco */
}
[data-bs-theme="light"] .navbar-hm .logo-img {
  filter: none;                         /* light: SVG rimane nero */
}
.navbar-hm .tagline {
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--muted);
  margin-left: 0.75rem;
  padding-left: 0.75rem;
  border-left: 1px solid var(--border);
}

/* ── Pulsanti ── */
.btn-primary {
  background: var(--lime);
  color: var(--lime-ink);
  border-color: var(--lime);
  font-weight: 600;
}
.btn-primary:hover, .btn-primary:focus {
  background: #a8c226;
  border-color: #a8c226;
  color: var(--lime-ink);
}
.btn-outline-secondary {
  border-color: var(--border);
  color: var(--muted);
}
.btn-outline-secondary:hover {
  background: var(--surface);
  border-color: var(--muted);
  color: var(--fg);
}

/* ── Focus ring ── */
a:focus-visible, button:focus-visible, input:focus-visible, select:focus-visible {
  outline: 2px solid var(--purple);
  outline-offset: 2px;
}
.form-control:focus, .form-select:focus {
  border-color: var(--purple);
  box-shadow: 0 0 0 3px rgba(108, 92, 231, 0.2);
  background: var(--surface);
  color: var(--fg);
}

/* ── Card ── */
.card {
  background: var(--surface);
  border-color: var(--border);
}
.card-stat .stat-value {
  font-family: "Cabinet Grotesk", sans-serif;
  font-size: 2rem;
  font-weight: 700;
  line-height: 1;
  color: var(--lime);
}
.card-stat .stat-label {
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--muted);
  margin-top: 4px;
}

/* ── Tabella ── */
.table {
  --bs-table-color: var(--fg);
  --bs-table-bg: transparent;
  --bs-table-border-color: var(--border);
}
.table thead th {
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
  border-bottom: 1px solid var(--border);
  font-weight: 500;
  background: var(--surface);
  white-space: nowrap;
}
.table tbody tr { border-bottom: 1px solid var(--border); }
.table tbody tr:hover { background: var(--bs-table-hover-bg); }
.table-dark thead { background: var(--surface); color: var(--muted); }

/* ── Badge fonte ── */
.badge-tl    { background: rgba(63,163,77,0.18);  color: var(--ok);   font-family: "JetBrains Mono", monospace; font-size: 11px; }
.badge-odoo  { background: rgba(224,161,43,0.18); color: var(--warn); font-family: "JetBrains Mono", monospace; font-size: 11px; }
.badge-both  { background: rgba(108,92,231,0.18); color: #a99cf0;     font-family: "JetBrains Mono", monospace; font-size: 11px; }
.badge-stima { background: rgba(144,151,168,0.14);color: var(--muted);font-family: "JetBrains Mono", monospace; font-size: 11px; }

/* ── Delta ore ── */
.delta-over  { color: var(--error); font-weight: 600; }
.delta-under { color: var(--ok);    font-weight: 600; }

/* ── Upload cards ── */
.upload-card { border: 1px dashed var(--border); background: var(--surface); transition: border-color 0.15s; }
.upload-card:focus-within { border-color: var(--purple); }
.upload-card .step-num {
  font-family: "Cabinet Grotesk", sans-serif;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.1em;
  color: var(--lime);
}

/* ── Form inputs ── */
.form-control, .form-select {
  background: var(--surface);
  border-color: var(--border);
  color: var(--fg);
}
.form-control::placeholder { color: var(--muted); }
.form-text { color: var(--muted); font-size: 12px; }
.form-label { font-size: 13px; font-weight: 500; color: var(--fg); }

/* ── Alert ── */
.alert-warning { background: rgba(224,161,43,0.12); border-color: rgba(224,161,43,0.3); color: var(--warn); }
.alert-danger  { background: rgba(214,69,58,0.12);  border-color: rgba(214,69,58,0.3);  color: var(--error); }
.alert-info    { background: rgba(108,92,231,0.12); border-color: rgba(108,92,231,0.3); color: #a99cf0; }

/* ── Dettaglio dipendenti ── */
.dettaglio-row td { background: rgba(255,255,255,0.025); }
[data-bs-theme="light"] .dettaglio-row td { background: rgba(0,0,0,0.03); }

/* ── Utility ── */
.text-muted   { color: var(--muted) !important; }
.label-caps   { font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--lime); font-weight:700; }
.page-eyebrow { font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--lime); font-weight:700; }
.w-search     { max-width: 400px; }
.col-nome     { max-width: 50vw; }
.pin-input    { font-size:1.5rem; letter-spacing:.5em; font-family:"JetBrains Mono",monospace; }
.pin-wrap     { width: 320px; }
.vh-center    { min-height: 80vh; }

/* ── Paginazione ── */
.pagination .page-link {
  background: var(--surface);
  border-color: var(--border);
  color: var(--fg);
  font-size: 13px;
  padding: 4px 10px;
}
.pagination .page-link:hover { background: var(--border); color: var(--fg); }
.pagination .page-item.active .page-link {
  background: var(--lime);
  border-color: var(--lime);
  color: var(--lime-ink);
  font-weight: 600;
}
.pagination .page-item.disabled .page-link { color: var(--muted); }

/* ── Toggle tema ── */
#btn-theme-toggle {
  background: none;
  border: 1px solid var(--border);
  color: var(--muted);
  border-radius: 6px;
  padding: 4px 10px;
  font-size: 13px;
  cursor: pointer;
  transition: border-color 0.15s, color 0.15s;
}
#btn-theme-toggle:hover { border-color: var(--muted); color: var(--fg); }
