/* ============================================================
 * WebMagnet CRM — Design system condiviso
 * Sfondo bianco, accent blu #2d6cdf, neutri grigi.
 *
 * Caricato in ogni pagina via _app_head.php (link in <head>).
 * Le pagine possono ancora override-are con i propri <style> inline;
 * questo file definisce solo le BASI + le utility .wm-*.
 * ============================================================ */

:root {
  --bg:           #ffffff;
  --bg-soft:      #f9fafb;
  --bg-muted:     #f3f4f6;
  --surface:      #ffffff;
  --border:       #e5e7eb;
  --border-strong:#d1d5db;
  --text:         #111827;
  --text-soft:    #4b5563;
  --text-muted:   #6b7280;
  --text-faint:   #9ca3af;

  --accent:       #2d6cdf;
  --accent-hover: #1f56be;
  --accent-soft:  #eaf1fc;
  --accent-text:  #ffffff;

  --success:      #16a34a;
  --success-soft: #dcfce7;
  --warn:         #d97706;
  --warn-soft:    #fef3c7;
  --danger:       #dc2626;
  --danger-soft:  #fee2e2;
  --info:         #0284c7;
  --info-soft:    #e0f2fe;
  --purple:       #7c3aed;
  --purple-soft:  #ede9fe;

  --radius-sm: 6px;
  --radius:    10px;
  --radius-lg: 14px;

  --shadow-sm: 0 1px 2px rgba(17,24,39,.05);
  --shadow:    0 1px 3px rgba(17,24,39,.06), 0 4px 12px rgba(17,24,39,.04);
  --shadow-lg: 0 10px 30px rgba(17,24,39,.08);

  --font: system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  --font-mono: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
}

/* Reset minimo (non aggressivo) */
*, *::before, *::after { box-sizing: border-box; }

html, body {
  background: var(--bg);
  color: var(--text);
  font-family: var(--font);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
body { margin: 0; }

/* Tipografia base */
h1, h2, h3, h4 { color: var(--text); font-weight: 600; line-height: 1.25; }
a { color: var(--accent); text-decoration: none; }
a:hover { color: var(--accent-hover); text-decoration: underline; }

hr { border: 0; border-top: 1px solid var(--border); margin: 16px 0; }

/* Card / superficie */
.wm-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 18px;
  box-shadow: var(--shadow-sm);
}

/* Bottoni — convenzione: .wm-btn = primario; .wm-btn-secondary = neutro; .wm-btn-danger; ecc. */
.wm-btn, button.wm-btn {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 9px 16px;
  background: var(--accent); color: var(--accent-text);
  border: 1px solid var(--accent); border-radius: var(--radius-sm);
  font: 600 14px/1 var(--font);
  cursor: pointer;
  transition: background .15s ease, transform .05s ease;
}
.wm-btn:hover  { background: var(--accent-hover); border-color: var(--accent-hover); color: #fff; text-decoration: none; }
.wm-btn:active { transform: translateY(1px); }
.wm-btn:disabled { opacity: .55; cursor: not-allowed; }

.wm-btn-secondary {
  background: var(--bg); color: var(--text);
  border: 1px solid var(--border-strong);
}
.wm-btn-secondary:hover { background: var(--bg-soft); color: var(--text); }

.wm-btn-ghost {
  background: transparent; color: var(--accent);
  border: 1px solid transparent;
}
.wm-btn-ghost:hover { background: var(--accent-soft); color: var(--accent-hover); }

.wm-btn-success { background: var(--success); border-color: var(--success); color: #fff; }
.wm-btn-success:hover { background: #15803d; border-color: #15803d; }
.wm-btn-danger  { background: var(--danger); border-color: var(--danger); color: #fff; }
.wm-btn-danger:hover  { background: #b91c1c; border-color: #b91c1c; }

/* Input/select/textarea */
.wm-input, input[type="text"].wm-input, input[type="email"].wm-input,
input[type="password"].wm-input, input[type="number"].wm-input,
input[type="url"].wm-input, input[type="tel"].wm-input,
input[type="search"].wm-input, input[type="date"].wm-input,
input[type="time"].wm-input, input[type="datetime-local"].wm-input,
select.wm-input, textarea.wm-input {
  width: 100%;
  padding: 9px 12px;
  background: var(--bg);
  color: var(--text);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius-sm);
  font: 14px/1.4 var(--font);
  transition: border-color .15s ease, box-shadow .15s ease;
}
.wm-input:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-soft); }

/* Tabelle base (opt-in con .wm-table) */
.wm-table {
  width: 100%;
  border-collapse: collapse;
  background: var(--surface);
}
.wm-table th, .wm-table td {
  padding: 9px 12px;
  text-align: left;
  border-bottom: 1px solid var(--border);
  font-size: 14px;
}
.wm-table th {
  font-weight: 600; color: var(--text-soft);
  background: var(--bg-soft);
  border-bottom: 1px solid var(--border-strong);
}
.wm-table tr:hover td { background: var(--bg-soft); }

/* Badge / chip */
.wm-badge {
  display: inline-block; padding: 2px 8px;
  font-size: 12px; font-weight: 600;
  border-radius: 999px;
  background: var(--bg-muted); color: var(--text-soft);
  border: 1px solid var(--border);
}
.wm-badge.success { background: var(--success-soft); color: #15803d; border-color: #bbf7d0; }
.wm-badge.warn    { background: var(--warn-soft);    color: #92400e; border-color: #fde68a; }
.wm-badge.danger  { background: var(--danger-soft);  color: #991b1b; border-color: #fecaca; }
.wm-badge.info    { background: var(--info-soft);    color: #075985; border-color: #bae6fd; }
.wm-badge.purple  { background: var(--purple-soft);  color: #5b21b6; border-color: #ddd6fe; }
.wm-badge.accent  { background: var(--accent-soft);  color: var(--accent-hover); border-color: #bfdbfe; }

/* Navbar condivisa — usata da _nav.php */
.wm-nav {
  background: var(--surface);
  border-bottom: 1px solid var(--border);
  padding: 10px 18px;
  display: flex; gap: 4px; flex-wrap: wrap; align-items: center;
  font: 14px/1 var(--font);
}
.wm-nav a {
  color: var(--text-soft);
  text-decoration: none;
  padding: 7px 12px;
  border-radius: var(--radius-sm);
  font-weight: 500;
  transition: background .15s ease, color .15s ease;
}
.wm-nav a:hover { background: var(--bg-soft); color: var(--text); text-decoration: none; }
.wm-nav a.primary {
  background: var(--accent); color: #fff;
}
.wm-nav a.primary:hover { background: var(--accent-hover); color: #fff; }
.wm-nav a.danger { color: var(--danger); }
.wm-nav a.danger:hover { background: var(--danger-soft); color: var(--danger); }
.wm-nav .wm-nav-spacer { margin-left: auto; }
.wm-nav .wm-nav-current {
  background: var(--accent-soft); color: var(--accent-hover); font-weight: 600;
}

/* Layout */
.wm-container { max-width: 1280px; margin: 0 auto; padding: 18px; }
.wm-container-wide { max-width: 100%; margin: 0; padding: 12px; }
.wm-stack > * + * { margin-top: 12px; }

/* Stati testo */
.wm-muted { color: var(--text-muted); }
.wm-soft  { color: var(--text-soft); }
.wm-tiny  { font-size: 12px; }

/* Helper focus-visible accessibilità */
:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }
