:root {
  --blue-950: #071a2f;
  --blue-900: #0a2f57;
  --blue-700: #1f5f9c;
  --blue-500: #3383d3;
  --cyan-300: #84d8e8;
  --mint-200: #c7f2ea;
  --paper: #f6fbff;
  --card: #ffffff;
  --ink: #10263d;
  --line: #c8d7e5;
  --danger: #b42318;
}
* { box-sizing: border-box; }
body {
  margin: 0;
  color: var(--ink);
  background: linear-gradient(120deg, #d8eef8, #eefaf6);
  font-family: "Segoe UI Variable", "Segoe UI", "Trebuchet MS", sans-serif;
}
.bg-layer {
  position: fixed;
  inset: 0;
  background:
    radial-gradient(900px 400px at 20% -10%, rgba(70, 145, 220, 0.25), transparent),
    radial-gradient(800px 500px at 95% 40%, rgba(132, 216, 232, 0.35), transparent);
  z-index: -1;
}
.topbar {
  position: sticky;
  top: 0;
  z-index: 20;
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  gap: 0;
  padding: 12px 18px;
  color: #fff;
  background: linear-gradient(90deg, #003580, #0067c0);
  box-shadow: 0 4px 18px rgba(0, 40, 120, 0.35);
  transition: padding .25s ease;
  overflow: visible;
  color: #fff;
}
.topbar-left {
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: center;
  gap: 6px;
  max-width: 320px;
}
.topbar-right {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
}
/* ── Topbar collapsed ── */
.topbar-collapsed .brand-copy,
.topbar-collapsed .userbox { display: none !important; }
.topbar-collapsed {
  padding: 4px 18px;
}
.topbar-collapsed .brand { min-width: 0; }
.topbar-collapsed .brand-mark { width: 32px; height: 32px; flex: 0 0 32px; }
.topbar-collapsed .brand-logo { max-height: 28px; }
/* ── Collapse button ── */
.topbar-collapse-btn {
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.30);
  color: #fff;
  border-radius: 6px;
  padding: 3px 9px;
  font-size: .75rem;
  cursor: pointer;
  line-height: 1.4;
  white-space: nowrap;
  transition: background .15s;
}
.topbar-collapse-btn:hover { background: rgba(255,255,255,.22); }
.table-row-sel { background: rgba(99,102,241,.12) !important; font-weight: 600; }
.table-row-sel td { border-left: 3px solid #6366f1; }
.hamburger {
  text-align: center;
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.35);
  color: #fff;
  border-radius: 8px;
  padding: 10px 22px;
  font-size: 1.08rem;
  font-weight: 700;
  cursor: pointer;
  line-height: 1.5;
  letter-spacing: .03em;
  white-space: nowrap;
  transition: background .15s;
}
.hamburger:hover { background: rgba(255,255,255,.22); }
/* Fix Google Translate <font> injection – previene spostamenti di layout */
.topbar font, .menu font { vertical-align: baseline !important; display: inline !important; }
.topbar-left > * { min-width: 0; overflow: hidden; text-overflow: ellipsis; }

.brand {
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: 0;
  flex: 0 0 auto;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  pointer-events: none;
}
.brand-mark {
  width: 84px;
  height: 84px;
  flex: 0 0 84px;
  display: grid;
  place-items: center;
  border-radius: 22px;
  background: rgba(255,255,255,.12);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.18), 0 10px 18px rgba(0, 20, 80, .20);
  overflow: hidden;
  padding: 4px;
}
.brand-logo {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}
.brand-nest2go {
  font-size: 1.05rem;
  font-weight: 900;
  letter-spacing: .04em;
  line-height: 1;
  margin-bottom: 1px;
}
.n2g-nest {
  background: linear-gradient(90deg, #1a8cff, #0055cc);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.n2g-2 {
  background: linear-gradient(90deg, #3abf5e, #1e8c3a);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.n2g-go {
  background: linear-gradient(90deg, #1a8cff, #0055cc);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.brand-copy {
  display: flex;
  flex-direction: column;
  min-width: 0;
}
.brand-title {
  font-size: 1.7rem;
  font-weight: 800;
  line-height: 1.05;
  letter-spacing: .02em;
}
.brand small {
  display: block;
  margin-top: 4px;
  font-size: .82rem;
  font-weight: 600;
  color: rgba(200,230,255,.85);
}
.menu {
  display: none;
  position: absolute;
  top: 100%;
  left: 0;
  min-width: 230px;
  z-index: 30;
  background: linear-gradient(180deg, #003580, #0067c0);
  padding: 8px 0;
  box-shadow: 0 8px 28px rgba(0,20,80,.55);
  max-height: 82vh;
  overflow-y: auto;
  border-radius: 0 0 10px 10px;
}
.menu.menu-open { display: flex; flex-direction: column; }
.menu a {
  color: #eef8ff;
  text-decoration: none;
  padding: 11px 22px;
  border-radius: 0;
  font-weight: 600;
  font-size: .96rem;
  border-bottom: 1px solid rgba(255,255,255,.07);
}
.menu a:hover { background: rgba(255,255,255,.13); }
.form-grid-4 { display: grid; grid-template-columns: repeat(4, minmax(140px, 1fr)); gap: 10px; }
.form-grid-4 label { display: grid; gap: 6px; font-size: .92rem; color: var(--ink-soft); }
.form-grid-4 input, .form-grid-4 select { border: 1px solid var(--line); border-radius: 10px; padding: 8px 10px; background: #fff; }
.muted { color: var(--ink-soft); }
.userbox {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 3px;
  background: rgba(255,255,255,.10);
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 12px;
  padding: 8px 12px;
  min-width: 152px;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.08), 0 4px 12px rgba(0,20,80,.20);
}
.userbox-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  min-height: 20px;
}
.userbox-label {
  font-size: .70em;
  font-weight: 700;
  color: rgba(200,230,255,.70);
  text-transform: uppercase;
  letter-spacing: .05em;
  white-space: nowrap;
}
.userbox-value {
  font-size: .82em;
  font-weight: 600;
  color: #eef8ff;
  text-align: right;
}
.userbox-btns {
  display: flex;
  flex-direction: row;
  gap: 4px;
  margin-top: 5px;
}
.btn-esci {
  flex: 1;
  text-align: center;
  font-size: .75em;
  font-weight: 700;
  padding: 5px 8px;
  border-radius: 8px;
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.22);
  color: #eef8ff;
  text-decoration: none;
  display: block;
  letter-spacing: .02em;
  white-space: nowrap;
  transition: background .15s;
}
.btn-esci:hover { background: rgba(255,255,255,.22); color: #fff; }
.topbar-left .btn-home,
.topbar-left .btn-indietro,
.topbar-left .btn-scheda,
.topbar-left .btn-esci,
.topbar-left .btn-tema,
.userbox-btns .btn-home,
.userbox-btns .btn-indietro {
  flex: 1;
  text-align: center;
  font-size: .88em;
  padding: 6px 10px;
  white-space: nowrap;
  font-weight: 700;
  border-radius: 8px;
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.22);
  color: #eef8ff;
  text-decoration: none;
  cursor: pointer;
  transition: background .15s;
}
.topbar-left .btn-home:hover,
.topbar-left .btn-indietro:hover,
.topbar-left .btn-scheda:hover,
.topbar-left .btn-esci:hover,
.topbar-left .btn-tema:hover,
.userbox-btns .btn-home:hover,
.userbox-btns .btn-indietro:hover { background: rgba(255,255,255,.22); color: #fff; }
/* ── Language switcher ──────────────────────────────────────────────────────── */
.lang-switcher {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 4px 6px;
  border-radius: 8px;
  background: rgba(255,255,255,.08);
}
.lang-globe { font-size: 1rem; opacity: .6; margin-right: 2px; line-height: 1; }
.lang-btn {
  display: inline-flex;
  align-items: center;
  text-decoration: none;
  background: none;
  border: none;
  cursor: pointer;
  opacity: .55;
  transition: opacity .18s, transform .18s;
  border-radius: 3px;
  padding: 1px;
}
.lang-btn img { display: block; border-radius: 2px; box-shadow: 0 1px 3px rgba(0,0,0,.35); }
.lang-btn:hover { opacity: .9; transform: scale(1.15); }
.lang-btn.lang-active { opacity: 1; outline: 2px solid rgba(255,255,255,.6); outline-offset: 1px; }
.badge-exp { font-size: .76em; padding: 2px 8px; border-radius: 6px; background: rgba(58,191,94,.20); color: #a8f0c0; white-space: nowrap; font-weight: 600; border: 1px solid rgba(58,191,94,.28); }
.badge-exp.in-scadenza { background: rgba(255,193,7,.20); color: #ffe082; border-color: rgba(255,193,7,.35); }
.badge-exp.scaduto { background: rgba(180,35,24,.28); color: #ffb3ae; border-color: rgba(180,35,24,.4); }
.badge-licenza-completa { font-size: .76em; padding: 2px 8px; border-radius: 6px; background: rgba(58,191,94,.22); color: #a8f0c0; font-weight: 700; white-space: nowrap; border: 1px solid rgba(58,191,94,.35); }
.userbox .badge { background: rgba(255,255,255,.15); color: #eef8ff; border: 1px solid rgba(255,255,255,.22); font-size: .76em; padding: 2px 8px; border-radius: 6px; }
.page {
  max-width: 1240px;
  margin: 18px auto;
  padding: 0 14px 24px;
  display: grid;
  gap: 12px;
}
.card {
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: 14px;
  box-shadow: 0 8px 24px rgba(7, 26, 47, 0.08);
  padding: 14px;
}
.grid-stats {
  display: grid;
  grid-template-columns: repeat(5, minmax(140px, 1fr));
  gap: 12px;
}
.stat h3 { margin: 0; color: #31506f; font-size: .95rem; }
.stat p { margin: 8px 0 0; font-size: 1.7rem; font-weight: 800; color: var(--blue-900); }
.section-head {
  display: flex;
  justify-content: space-between;
  gap: 8px;
  align-items: center;
  margin-bottom: 10px;
}
h2 { margin: 0; color: var(--blue-900); font-size: 1.2rem; }
.form-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(140px, 1fr));
  gap: 10px;
}
.field {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.field.col-2 { grid-column: span 2; }
.field.col-4 { grid-column: span 4; }
label { font-weight: 700; color: #2f4f6e; font-size: .9rem; }
input, select, textarea {
  width: 100%;
  border: 1px solid var(--line);
  border-radius: 9px;
  padding: 10px;
  font-size: .94rem;
  background: #fff;
  color: var(--ink);
}
textarea { min-height: 84px; resize: vertical; }
.btn {
  border: 1px solid var(--blue-700);
  background: linear-gradient(180deg, var(--blue-500), var(--blue-700));
  color: #fff;
  border-radius: 9px;
  padding: 10px 12px;
  font-weight: 700;
  cursor: pointer;
  text-decoration: none;
}
.btn-ghost {
  border: 1px solid #8cb5d7;
  background: #eaf4ff;
  color: #12395c;
}
.btn-danger {
  border-color: #d63535;
  background: linear-gradient(180deg, #ff6d6d, #d63535);
}
.actions { display: flex; gap: 8px; align-items: center; }
.table-wrap {
  overflow: auto;
  max-height: 520px;
  border: 1px solid #d8e6f0;
  border-radius: 10px;
}
table { width: 100%; border-collapse: collapse; background: #fff; }
th, td {
  text-align: left;
  padding: 8px 7px;
  border-bottom: 1px solid #e7eff5;
  vertical-align: top;
  font-size: .92rem;
}
th {
  background: #f1f8ff;
  color: #2d4e6f;
  position: sticky;
  top: 0;
}
.alerts { display: grid; gap: 8px; }
.alert-item {
  border: 1px solid #f4c7c7;
  background: #fff3f3;
  color: var(--danger);
  border-radius: 8px;
  padding: 9px 11px;
  font-weight: 600;
}
.login-wrap {
  min-height: 100vh;
  display: grid;
  place-items: center;
  padding: 16px;
  background: linear-gradient(145deg, #08213d 0%, #1f5f9c 55%, #84d8e8 100%);
}
.login-card {
  width: min(520px, 96vw);
  background: rgba(255,255,255,0.98);
  padding: 22px 20px;
}
.login-card h1 { margin: 0 0 12px 0; color: var(--blue-950); font-size: 1.6rem; }
.login-brand {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 18px;
  padding-bottom: 16px;
  border-bottom: 1px solid #e2eaf2;
}
.login-logo {
  height: 64px;
  width: auto;
  flex: 0 0 auto;
  filter: drop-shadow(0 3px 8px rgba(0,0,0,0.12));
}
.login-brand-copy { flex: 1; }
.login-brand-copy h1 { margin: 4px 0 0; font-size: 1rem; color: #5b6472; font-weight: 600; }
.login-card .alerts { margin-bottom: 10px; }
.login-card .form-grid { grid-template-columns: 140px 1fr; gap: 12px; align-items: center; }
.login-card .form-grid .field { margin: 0; }
.login-card .form-grid .field.col-2 { grid-column: 1 / -1; }
.login-card .form-grid input { background: #eaf6ff; border: 1px solid #cfeaf9; border-radius: 10px; padding: 10px 12px; }
.login-card .form-grid label { font-weight: 700; color: #123049; }
.login-card .form-grid .actions { display: flex; justify-content: flex-end; align-items: center; }
.login-card .form-grid .actions .btn { padding: 10px 18px; border-radius: 12px; }

@media (max-width: 980px) {
  .grid-stats { grid-template-columns: repeat(2, minmax(120px, 1fr)); }
  .form-grid { grid-template-columns: repeat(2, minmax(140px, 1fr)); }
  .field.col-4 { grid-column: span 2; }
}
@media (max-width: 700px) {
  .topbar {
    padding: 8px 12px;
    gap: 8px;
  }
  .brand {
    gap: 8px;
  }
  .brand-mark {
    width: 44px;
    height: 44px;
    flex-basis: 44px;
    border-radius: 14px;
  }
  .brand-mark svg {
    width: 34px;
    height: 34px;
  }
  .brand-title { font-size: 1.02rem; }
  .brand small { font-size: .72rem; }
  .userbox { min-width: 120px; padding: 6px 10px; font-size: .88em; }
  .form-grid { grid-template-columns: 1fr; }
  .field.col-2, .field.col-4 { grid-column: span 1; }
  .grid-stats { grid-template-columns: repeat(2, 1fr); }
  .quick-actions { grid-template-columns: repeat(2, 1fr); }
  .stats-grid { grid-template-columns: 1fr; }
  .stats-grid-compact { grid-template-columns: repeat(2, 1fr); }
  .wizard-stepper { grid-template-columns: 1fr; }
  .card { padding: 10px; }
  .btn { padding: 10px 12px; min-height: 40px; }
  .page { margin: 10px auto; }
}

@media (max-width: 480px) {
  .grid-stats { grid-template-columns: 1fr 1fr; }
  .quick-actions { grid-template-columns: 1fr; }
  .stats-grid-compact { grid-template-columns: repeat(2, 1fr); }
  td, th { font-size: .83rem; padding: 6px 5px; }
}

/* ── Filtri avanzati ── */
.filter-bar {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: flex-end;
  padding: 8px 0 6px;
  border-bottom: 1px solid var(--line);
  margin-bottom: 4px;
}
.filter-bar .field { flex: 0 1 175px; }

/* ── App launcher ── */
.launcher-shell {
  padding: 18px;
  background: linear-gradient(180deg, rgba(255,255,255,.96), rgba(252,248,255,.92));
}
.launcher-banner {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 24px;
  margin-bottom: 16px;
  padding: 18px 20px;
  border-radius: 22px;
  background: linear-gradient(135deg, #e5f5e7, #eef9f3);
  border: 1px solid #d3ead8;
  box-shadow: 0 12px 28px rgba(16, 38, 61, 0.08);
}
.launcher-logo {
  height: 90px;
  width: auto;
  flex: 0 0 auto;
  filter: drop-shadow(0 4px 10px rgba(0,0,0,0.12));
}
.launcher-copy {
  flex: 0 1 auto;
  text-align: left;
}
.launcher-nest2go {
  display: block;
  font-size: 2rem;
  font-weight: 800;
  letter-spacing: -0.5px;
  line-height: 1;
  margin-bottom: 4px;
}
.launcher-banner h1 {
  margin: 0;
  color: #111827;
  font-size: 2rem;
}
.launcher-banner p {
  margin: 6px 0 0;
  color: #5b6472;
  font-size: 1rem;
}
.launcher-icon {
  width: 76px;
  height: 76px;
  display: grid;
  place-items: center;
  border-radius: 24px;
  background: #eadcfb;
  color: #5b3db4;
  font-size: 2rem;
  flex: 0 0 76px;
}
.launcher-icon-alt {
  background: #fff4bf;
  color: #9a6700;
}
.app-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(140px, 1fr));
  gap: 8px;
}
.app-card {
  min-height: 150px;
  padding: 14px 10px;
  border-radius: 16px;
  border: 1px solid #e6ebf5;
  background: rgba(255,255,255,.94);
  box-shadow: 0 4px 12px rgba(16, 38, 61, 0.07);
  text-decoration: none;
  color: inherit;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  text-align: center;
  transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease;
}
.app-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 16px 32px rgba(16, 38, 61, 0.12);
  border-color: #bfd0e5;
}
.app-card-icon {
  width: 52px;
  height: 52px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  margin-bottom: 8px;
  font-size: 1.4rem;
}
.app-card h3 {
  margin: 0;
  color: #111827;
  font-size: 1.1rem;
}
.app-card p {
  margin: 4px 0 0;
  color: #666f7c;
  font-size: 0.82rem;
  line-height: 1.25;
}
.tone-mint .app-card-icon { background: #e4f3e8; color: #2f9e44; }
.tone-sky .app-card-icon { background: #e8f0ff; color: #339af0; }
.tone-violet .app-card-icon { background: #efebff; color: #5f3dc4; }
.tone-teal .app-card-icon { background: #e2f7f4; color: #0f766e; }
.tone-pink .app-card-icon { background: #fde8f1; color: #e11d48; }
.tone-lavender .app-card-icon { background: #f3e8ff; color: #7c3aed; }
.tone-amber .app-card-icon { background: #fff1df; color: #f59e0b; }
.tone-gold .app-card-icon { background: #fff4d6; color: #eab308; }
.tone-slate .app-card-icon { background: #eef2f7; color: #64748b; }
.tone-orchid .app-card-icon { background: #f8e6fb; color: #a21caf; }
.tone-sand .app-card-icon { background: #f4eae4; color: #7c5c4b; }

/* sfondo e bordo della card per ogni tone */
.tone-mint    { background: #f4fbf6; border-color: #b2dfc0; }
.tone-sky     { background: #f0f6ff; border-color: #b3d0f7; }
.tone-violet  { background: #f5f3ff; border-color: #c4b5fd; }
.tone-teal    { background: #f0fbf9; border-color: #99d6cf; }
.tone-pink    { background: #fff0f5; border-color: #f9a8c9; }
.tone-lavender{ background: #faf5ff; border-color: #d8b4fe; }
.tone-amber   { background: #fffbf0; border-color: #fcd89a; }
.tone-gold    { background: #fefce8; border-color: #fde047; }
.tone-slate   { background: #f8fafc; border-color: #cbd5e1; }
.tone-orchid  { background: #fdf4ff; border-color: #e879f9; }
.tone-sand    { background: #fdf8f5; border-color: #d6b8aa; }

/* hover con bordo più scuro */
.tone-mint:hover    { border-color: #2f9e44; }
.tone-sky:hover     { border-color: #339af0; }
.tone-violet:hover  { border-color: #5f3dc4; }
.tone-teal:hover    { border-color: #0f766e; }
.tone-pink:hover    { border-color: #e11d48; }
.tone-lavender:hover{ border-color: #7c3aed; }
.tone-amber:hover   { border-color: #f59e0b; }
.tone-gold:hover    { border-color: #eab308; }
.tone-slate:hover   { border-color: #64748b; }
.tone-orchid:hover  { border-color: #a21caf; }
.tone-sand:hover    { border-color: #7c5c4b; }

/* ── Dashboard layout ── */
.dash-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.econ-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
.econ-num { margin: 8px 0 0; font-size: 1.6rem; font-weight: 800; }
.kpi-grid { display: grid; grid-template-columns: repeat(4, minmax(140px, 1fr)); gap: 10px; }
.dash-ops-grid { display: grid; grid-template-columns: 1.1fr .9fr; gap: 12px; }
.focus-list, .timeline-list, .alert-board { display: grid; gap: 8px; }
.focus-item, .timeline-item, .alert-row {
  text-decoration: none;
  color: inherit;
  border: 1px solid #d8e6f0;
  border-radius: 10px;
  padding: 10px;
  background: #f9fcff;
  display: grid;
  gap: 4px;
}
.focus-item:hover, .timeline-item:hover, .alert-row:hover { border-color: #9cc2e5; background: #f1f8ff; }
.timeline-date { font-size: .82rem; font-weight: 700; color: #2f4f6e; }
.level-high, .prio-high { border-left: 4px solid #dc2626; }
.level-mid, .prio-mid { border-left: 4px solid #d97706; }
.level-ok, .prio-low { border-left: 4px solid #0a7c44; }
.quick-actions { display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px; }
.quick-actions .btn { text-align: center; }
.form-grid-4 { display: grid; grid-template-columns: repeat(4, minmax(140px, 1fr)); gap: 10px; }
.form-grid-4 label { display: grid; gap: 6px; font-size: .92rem; color: #4f5d6f; }
.form-grid-4 input, .form-grid-4 select { border: 1px solid #d1deec; border-radius: 10px; padding: 8px 10px; background: #fff; }
.muted { color: #5d6a7a; }

.labels-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 10px; }
.label-card { border: 1px dashed #9cc2e5; border-radius: 12px; background: #f6fbff; padding: 10px 12px; }
.label-card h3 { margin: 0 0 6px; font-size: 1.05rem; color: #173a60; }
.label-card p { margin: 2px 0; font-size: .9rem; }

/* ── Covate dettaglio eventi uova ── */
.event-legend { display: flex; gap: 8px; flex-wrap: wrap; }
.event-counts { display: flex; gap: 8px; flex-wrap: wrap; }
.legend-chip {
  display: inline-block;
  padding: 4px 10px;
  border-radius: 999px;
  font-size: .82rem;
  font-weight: 700;
  border: 1px solid transparent;
}
.legend-real {
  background: #dcfce7;
  color: #166534;
  border-color: #86efac;
}
.legend-pred {
  background: #fff7ed;
  color: #9a3412;
  border-color: #fed7aa;
}
.legend-row-full {
  background: #dcfce7;
  color: #166534;
  border-color: #86efac;
}
.legend-row-partial {
  background: #fef3c7;
  color: #92400e;
  border-color: #fcd34d;
}
.legend-row-empty {
  background: #fee2e2;
  color: #991b1b;
  border-color: #fca5a5;
}
select.event-input {
  min-width: 120px;
}
.event-input.event-real {
  background: #f0fdf4;
  border-color: #86efac;
}
.event-input.event-pred {
  background: #fff7ed;
  border-color: #fdba74;
}
.event-row-full {
  background: #f0fdf4;
}
.event-row-partial {
  background: #fffbeb;
}
.event-row-empty {
  background: #fef2f2;
}
.event-row-full td,
.event-row-partial td,
.event-row-empty td {
  background: transparent;
}
.date-pick-wrap {
  display: flex;
  align-items: center;
}
.dp-hidden {
  position: absolute;
  opacity: 0;
  pointer-events: none;
  width: 0;
  height: 0;
  border: none;
  padding: 0;
}

.wizard-stepper { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; margin-top: 10px; }
.wizard-step { border: 1px solid #c8d7e5; background: #eef5fb; border-radius: 10px; padding: 8px 10px; text-align: center; color: #48627f; font-weight: 600; }
.wizard-step.active { background: #dbeafe; border-color: #8db5e0; color: #0f3d70; }

/* ── Stat colori ── */
.stat.presenti p { color: #0a7c44; }
.stat.ceduti p { color: #d97706; }
.stat.morti p { color: #dc2626; }
.positivo { color: #0a7c44 !important; }
.negativo { color: #dc2626 !important; }

/* ── Stato badge uccelli ── */
.stato-badge { display:inline-block; padding:2px 8px; border-radius:10px; font-size:.82rem; font-weight:700; }
.stato-presente { background:#d1fae5; color:#065f46; }
.stato-ceduto { background:#fef3c7; color:#92400e; }
.stato-morto { background:#fee2e2; color:#991b1b; }

/* ── Ruolo badge ── */
.badge { display:inline-block; padding:2px 8px; border-radius:12px; font-size:.8rem; font-weight:700; }
.badge.admin { background:#dbeafe; color:#1d4ed8; }
.badge.viewer { background:#f0fdf4; color:#166534; }

/* ── Upload foto ── */
.upload-form { display:flex; gap:8px; align-items:center; flex-wrap:wrap; }
.bird-photo { width:50px; height:50px; object-fit:cover; border-radius:6px; border:1px solid var(--line); vertical-align:middle; }

/* ── Log table ── */
.log-action { font-family:monospace; font-size:.85rem; color:#5b4f9e; font-weight:700; }

@media (max-width: 980px) {
  .app-grid { grid-template-columns: repeat(2, minmax(140px, 1fr)); }
  .launcher-banner h1 { font-size: 1.7rem; }
  .dash-grid { grid-template-columns: 1fr; }
  .econ-grid { grid-template-columns: repeat(2, 1fr); }
  .kpi-grid { grid-template-columns: repeat(2, minmax(140px, 1fr)); }
  .dash-ops-grid { grid-template-columns: 1fr; }
  .form-grid-4 { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 700px) {
  .launcher-shell { padding: 14px; }
  .launcher-banner {
    flex-direction: column;
    padding: 16px;
    border-radius: 18px;
    align-items: center;
  }
  .launcher-icon {
    width: 62px;
    height: 62px;
    font-size: 1.7rem;
    border-radius: 20px;
  }
  .launcher-copy { order: 2; }
  .launcher-banner h1 { font-size: 1.45rem; }
  .launcher-banner p { font-size: .95rem; }
  .app-grid { grid-template-columns: repeat(2, 1fr); gap: 10px; }
  .app-card { min-height: 130px; border-radius: 16px; }
  .app-card h3 { font-size: 1rem; }
  .econ-grid { grid-template-columns: 1fr; }
  .kpi-grid { grid-template-columns: 1fr 1fr; }
  .form-grid-4 { grid-template-columns: 1fr; }
}

@media print {
  .topbar, .footer, .btn, form, .section-head .btn, .quick-actions { display: none !important; }
  body { background: #fff; }
  .card { box-shadow: none; border: 1px solid #ddd; }
  .labels-grid { grid-template-columns: repeat(3, 1fr); gap: 8px; }
  .label-url-hint { display: none !important; }
}

/* ================================================================
   OTTIMIZZAZIONI TABLET / SMARTPHONE
   ================================================================ */

/* Elimina 300 ms delay su tap per tutti i controlli interattivi */
button, a, input, select, textarea, label, .btn {
  touch-action: manipulation;
}

/* Safe-area per iPhone con notch / Dynamic Island */
.topbar {
  padding-left:  max(18px, env(safe-area-inset-left));
  padding-right: max(18px, env(safe-area-inset-right));
}
@supports (padding: env(safe-area-inset-top)) {
  .topbar { padding-top: max(12px, env(safe-area-inset-top)); }
  .footer { padding-bottom: max(16px, env(safe-area-inset-bottom)); }
}

/* Scroll tabelle con momentum su iOS */
.table-wrap {
  -webkit-overflow-scrolling: touch;
  overscroll-behavior-x: contain;
}
.filter-bar {
  overscroll-behavior-x: contain;
}

/* ── Tablet  (≤ 900 px) ── */
@media (max-width: 900px) {
  .page { padding: 0 10px 20px; }
  .card  { padding: 12px; }
  .section-head { flex-wrap: wrap; gap: 8px; }
  .actions { flex-wrap: wrap; }
}

/* ── Smartphone  (≤ 600 px) ── */
@media (max-width: 600px) {
  /* Previeni zoom automatico iOS sugli input (min 16px richiesto) */
  input, select, textarea { font-size: 16px !important; }

  /* Topbar compatta: nascondi brand-copy e userbox */
  .brand-copy { display: none !important; }
  .brand-mark  { width: 36px; height: 36px; flex: 0 0 36px; border-radius: 10px; }
  .userbox     { display: none !important; }
  .topbar      { padding: 6px max(10px, env(safe-area-inset-left)) 6px max(10px, env(safe-area-inset-right)); gap: 4px; }
  .topbar-left { grid-template-columns: repeat(3, auto); gap: 4px; max-width: none; }
  .topbar-left .btn-home,
  .topbar-left .btn-indietro,
  .topbar-left .btn-scheda,
  .topbar-left .btn-esci,
  .topbar-left .btn-tema { font-size: .72em; padding: 5px 7px; min-height: 36px; }
  .hamburger { font-size: .82rem; padding: 6px 12px; min-height: 36px; }

  /* Touch target minimo 44 px per bottoni e input */
  .btn, button { min-height: 44px; }
  input, select { min-height: 44px; }

  /* Section-head: titolo sopra, azioni sotto a piena larghezza */
  .section-head {
    flex-direction: column;
    align-items: flex-start;
    gap: 6px;
  }
  .section-head .actions { width: 100%; }
  .section-head .actions .btn { flex: 1; text-align: center; }

  /* Pagina e card */
  .page { padding: 0 8px 14px; margin: 8px auto; gap: 8px; }
  .card { padding: 10px; }
  h2    { font-size: 1.05rem; }

  /* Stats compact */
  .stats-grid-compact { grid-template-columns: repeat(2, 1fr); }
  .grid-stats         { grid-template-columns: 1fr 1fr; }
}

/* ── Smartphone piccolo  (≤ 380 px) ── */
@media (max-width: 380px) {
  .topbar-left .btn-home,
  .topbar-left .btn-indietro,
  .topbar-left .btn-scheda,
  .topbar-left .btn-esci,
  .topbar-left .btn-tema { font-size: .65em; padding: 4px 5px; }
  .hamburger { font-size: .75rem; padding: 5px 9px; }
  td, th   { font-size: .76rem; padding: 5px 4px; }
  h2       { font-size: .95rem; }
  .btn     { padding: 8px 9px; font-size: .86rem; }
  .page    { padding: 0 5px 10px; }
  .card    { padding: 8px; }
}

/* ── Footer ── */
.footer {
  text-align: center;
  padding: 16px;
  background: #f1f5f9;
  border-top: 1px solid var(--line);
  margin-top: 24px;
  font-size: .9rem;
  color: #36476b;
}
.footer p { margin: 4px 0; }
.footer a {
  color: var(--blue-700);
  text-decoration: none;
  font-weight: 600;
}
.footer a:hover { text-decoration: underline; }
.brand small { display: block; font-size: .75rem; font-weight: 600; margin-top: 2px; color: #c7f2ea; }

/* ── Statistiche ── */
.chart-container {
  position: relative;
  width: 100%;
  height: 300px;
  margin-bottom: 16px;
}
.stats-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.stats-grid-compact { display: grid; grid-template-columns: repeat(5, 1fr); gap: 12px; text-align: center; }
.stat-label { color: #666; font-size: .9rem; margin: 0; }
.stat-value { color: var(--blue-900); font-size: 1.8rem; font-weight: 800; margin: 4px 0 0; }

/* ── Genealogia ── */
.genealogia-tree { padding: 20px; }
.tree-container { font-size: .95rem; }
.tree-gen { margin: 16px 0; }
.tree-box {
  background: #f8fbfe;
  border: 2px solid var(--blue-500);
  border-radius: 8px;
  padding: 12px;
  text-align: center;
  transition: all 0.2s;
  cursor: pointer;
}
.tree-box:hover { box-shadow: 0 4px 12px rgba(31, 95, 156, 0.15); }
.tree-box.empty { background: #f0f0f0; border-color: #ccc; color: #999; }
.tree-box.padre { border-color: #1d4ed8; background: #dbeafe; }
.tree-box.madre { border-color: #9d3d03; background: #fed7aa; }
.tree-box.tu { border: 3px solid var(--blue-700); background: #eaf4ff; font-weight: 700; }
.tree-box.figlio { border-color: #059669; background: #d1fae5; }
.nonni-row { display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px; }
.nonni-col { text-align: center; }
.nonni-label { font-size: .8rem; color: #666; margin-bottom: 4px; font-weight: 600; }
.genitori-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.genitore-col { text-align: center; }
.genitore-label { font-size: .9rem; color: #666; margin-bottom: 6px; font-weight: 700; }
.figli-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: 10px; }
.figlio-col { }

@media (max-width: 980px) {
  .stats-grid { grid-template-columns: 1fr; }
  .stats-grid-compact { grid-template-columns: repeat(3, 1fr); }
  .nonni-row { grid-template-columns: repeat(2, 1fr); }
  .figli-grid { grid-template-columns: repeat(auto-fill, minmax(120px, 1fr)); }
}
@media (max-width: 700px) {
  .stats-grid-compact { grid-template-columns: repeat(2, 1fr); }
}

/* ── Famiglia ── */
.famiglia-section { padding: 12px 0; }
.famiglia-genitori { margin-bottom: 16px; }
.famiglia-figli { }
.familia-link { margin-top: 4px; }
.familia-link a { color: var(--blue-700); text-decoration: none; font-weight: 600; }
.familia-link a:hover { text-decoration: underline; }

/* ── Utilità mancanti ──────────────────────────────────────────────────── */
.empty-msg { color: #8a9ab8; font-style: italic; padding: 8px 0; }

/* ── Responsive mobile — miglioramenti ────────────────────────────────── */
@media (max-width: 980px) {
  .kpi-grid { grid-template-columns: repeat(2, 1fr); }
  .form-grid-4 { grid-template-columns: repeat(2, 1fr); }
  .chart-container { height: 250px; }
}
@media (max-width: 700px) {
  .chart-container { height: 200px; }
  .kpi-grid { grid-template-columns: repeat(2, 1fr); }
  .form-grid-4 { grid-template-columns: 1fr 1fr; }
  .section-head { flex-wrap: wrap; }
  .actions { flex-wrap: wrap; }
  .filter-bar { overflow-x: auto; flex-wrap: nowrap; padding-bottom: 4px; -webkit-overflow-scrolling: touch; }
  .filter-bar .field { flex: 0 0 145px; }
  .table-wrap { -webkit-overflow-scrolling: touch; }
}
@media (max-width: 480px) {
  .chart-container { height: 170px; }
  .kpi-grid { grid-template-columns: 1fr 1fr; }
  .form-grid-4 { grid-template-columns: 1fr; }
  .section-head h2, .section-head h3 { font-size: 1rem; }
}
