/* Colori strutturali (neutri). Il colore di brand è --color-primary, iniettato a
   runtime dal branding del tenant in base.html (F3); qui solo il fallback neutro. */
:root { --fg: #1d2433; --muted: #6b7280; --err: #b91c1c; --color-primary: #334155; --accent: var(--color-primary); }

/* Pelle legacy: la navbar e gli accenti usano il colore di brand del tenant
   (per ABV è il blu legacy, per gli altri il loro colore personalizzato). */
.app-navbar { background: var(--color-primary); }
.text-brand { color: var(--color-primary) !important; }
.btn-primary {
  --bs-btn-bg: var(--color-primary);
  --bs-btn-border-color: var(--color-primary);
  --bs-btn-hover-bg: var(--color-primary);
  --bs-btn-hover-border-color: var(--color-primary);
  --bs-btn-active-bg: var(--color-primary);
  --bs-btn-active-border-color: var(--color-primary);
  --bs-btn-disabled-bg: var(--color-primary);
  --bs-btn-disabled-border-color: var(--color-primary);
}

/* --- Tweak mobile-first portati dal legacy --- */
body { -webkit-tap-highlight-color: transparent; }
@media (max-width: 767px) { .card { border-radius: 12px !important; } }
@media (max-width: 575px) {
  .form-control, .form-select { font-size: 16px !important; } /* evita lo zoom iOS */
}
.list-group-item { border-left: none; border-right: none; }
.list-group-item:first-child { border-top: none; }
.list-group-item:last-child { border-bottom: none; }
input[type=number] { -moz-appearance: textfield; }
input[type=number]::-webkit-inner-spin-button,
input[type=number]::-webkit-outer-spin-button { -webkit-appearance: none; margin: 0; }
@media (display-mode: standalone) { .navbar.sticky-top { padding-top: env(safe-area-inset-top); } }

/* Banner ambiente (staging/dev) */
.env-banner { background: #f59e0b; color: #1d2433; text-align: center; font-weight: 600; padding: .25rem; }

/* Banner impersonificazione (super-admin «entra come utente») */
.impersonation-banner {
  background: #7c3aed; color: #fff; padding: .4rem 1rem;
  display: flex; align-items: center; justify-content: center; gap: .5rem;
  flex-wrap: wrap; font-size: .9rem;
}

.field-error { color: var(--err); font-size: .85rem; }

/* Maniglia di trascinamento per il riordino spese */
.drag-handle { cursor: grab; touch-action: none; }
.drag-handle:active { cursor: grabbing; }
.sortable-ghost { opacity: .5; }

/* Badge natura riga (rimborso/azienda); base .badge la fornisce Bootstrap */
.badge-reimburse { background: #e6f4ea; color: #1e7e34; }
.badge-company { background: #eceff1; color: #455a64; }
.totals ul { list-style: none; padding-left: 0; }

/* Intestazione documenti brandizzata (usata anche nei PDF standalone) */
.doc-header { display: flex; align-items: center; gap: .75rem; border-bottom: 3px solid var(--pdf-header-color); padding-bottom: .5rem; margin-bottom: 1rem; }
.doc-header img { height: 2.5rem; width: auto; }
.doc-header h1 { margin: 0; }
