:root {
  --sega-blue: #1763a6;
  --sega-blue-d: #124e83;
  --sega-teal: #0e9aa7;
  --sega-cyan: #17a2b8;
  --sega-bg: #f1f4f8;
  --sega-ink: #1f2a37;
}

body {
  background: var(--sega-bg);
  color: var(--sega-ink);
  -webkit-font-smoothing: antialiased;
}

.btn-primary {
  --bs-btn-bg: var(--sega-blue);
  --bs-btn-border-color: var(--sega-blue);
  --bs-btn-hover-bg: var(--sega-blue-d);
  --bs-btn-hover-border-color: var(--sega-blue-d);
  --bs-btn-active-bg: var(--sega-blue-d);
  --bs-btn-active-border-color: var(--sega-blue-d);
}

a, .nav-link { color: var(--sega-blue); }

/* ===================== BRAND ===================== */
.brand-badge {
  width: 64px;
  height: 64px;
  border-radius: 18px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: 30px;
  background: linear-gradient(135deg, var(--sega-blue) 0%, var(--sega-teal) 100%);
  box-shadow: 0 6px 18px rgba(23, 99, 166, .35);
}
.brand-badge.sm {
  width: 34px;
  height: 34px;
  border-radius: 9px;
  font-size: 17px;
  box-shadow: none;
}

/* ===================== LOGIN ===================== */
.login-wrap {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem;
  background:
    radial-gradient(1200px 600px at 110% -10%, rgba(14, 154, 167, .18), transparent),
    radial-gradient(900px 500px at -10% 110%, rgba(23, 99, 166, .18), transparent),
    var(--sega-bg);
}
.login-card {
  width: 100%;
  max-width: 410px;
  border: none;
  border-radius: 18px;
}

/* ===================== NAVBAR ===================== */
.app-navbar {
  background: #fff;
  border-bottom: 1px solid #e3e8ef;
  box-shadow: 0 1px 4px rgba(16, 36, 60, .04);
}
.app-navbar .navbar-brand { color: var(--sega-ink); }
.app-navbar .nav-link {
  color: #54616e;
  font-weight: 500;
  border-radius: 8px;
  padding-inline: .7rem;
}
.app-navbar .nav-link:hover { background: #eef3f8; color: var(--sega-blue); }
.app-navbar .nav-link.active {
  background: rgba(23, 99, 166, .1);
  color: var(--sega-blue);
}

.app-section { animation: fade .15s ease; }
@keyframes fade { from { opacity: 0; transform: translateY(3px); } to { opacity: 1; transform: none; } }

/* ===================== MAPPA ===================== */
#map {
  height: 72vh;
  min-height: 420px;
  border-radius: 12px;
  overflow: hidden;
  z-index: 0;
}
.map-legend .lg-item { display: inline-flex; align-items: center; gap: .35rem; }

/* ===================== BADGE ESITO ===================== */
.badge-esito {
  font-weight: 600;
  letter-spacing: .2px;
  color: #fff;
}
.esito-in_verifica  { background: #d9930a; }
.esito-fibra        { background: var(--sega-blue); }
.esito-radio        { background: var(--sega-teal); }
.esito-fibra_radio  { background: #1f9d57; }
.esito-non_fattibile{ background: #c0392b; }
.esito-dot {
  width: 11px; height: 11px; border-radius: 50%;
  display: inline-block; vertical-align: middle;
  border: 2px solid #fff; box-shadow: 0 0 0 1px rgba(0,0,0,.15);
}

/* ===================== BADGE STATO ===================== */
.badge-stato { font-weight: 600; }
.stato-nuova            { background: #e9ecef; color: #495057; }
.stato-in_lavorazione   { background: #cfeffc; color: #0a6c84; }
.stato-quotata          { background: #d6e6f7; color: var(--sega-blue-d); }
.stato-ordinata         { background: #fdeecb; color: #92670a; }
.stato-contrattualizzata{ background: #d4f3e0; color: #15693c; }
.stato-sospesa          { background: #e9ecef; color: #6c757d; }
.stato-persa            { background: #f9d7d3; color: #a5291b; }

/* ===================== PALLINI COPERTURE ===================== */
.pallino {
  width: 13px; height: 13px;
  border-radius: 50%;
  display: inline-block;
  vertical-align: middle;
  border: 1px solid rgba(0,0,0,.12);
}
.cop-ok            { background: #25a35a; }
.cop-ordinato      { background: var(--sega-blue); }
.cop-in_attesa     { background: #e0a82e; }
.cop-in_delivery   { background: #7e57c2; }
.cop-ko            { background: #d9534f; }
.cop-non_verificato{ background: #cbd3da; }

.cop-cluster { display: inline-flex; gap: 3px; align-items: center; flex-wrap: wrap; }
.cop-chip {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: .72rem; line-height: 1;
  padding: 2px 6px; border-radius: 20px;
  background: #f1f4f8; border: 1px solid #e1e7ee;
  white-space: nowrap;
}

/* ===================== TABELLE ===================== */
.table-fattibilita td { vertical-align: middle; }
.table-fattibilita .azienda-nome { font-weight: 600; }
.table-fattibilita .azienda-sub { font-size: .78rem; color: #7a8794; }
.coperture-table th { font-size: .76rem; background: #f6f8fb; }
.coperture-table td { padding: .3rem .4rem; }

/* ===================== STAT CARDS ===================== */
.stat-card {
  border: none; border-radius: 14px;
  background: #fff;
  box-shadow: 0 2px 10px rgba(16, 36, 60, .05);
}
.stat-card .stat-num { font-size: 1.7rem; font-weight: 700; line-height: 1; }
.stat-card .stat-lbl { font-size: .8rem; color: #7a8794; }
.stat-card .stat-ico {
  width: 42px; height: 42px; border-radius: 11px;
  display: flex; align-items: center; justify-content: center;
  font-size: 20px; color: #fff;
}

/* ===================== CRONOLOGIA TIMELINE ===================== */
.timeline { position: relative; padding-left: 26px; }
.timeline::before {
  content: ""; position: absolute;
  left: 9px; top: 4px; bottom: 4px;
  width: 2px; background: #e1e7ee;
}
.tl-item { position: relative; padding-bottom: 1.1rem; }
.tl-dot {
  position: absolute; left: -22px; top: 2px;
  width: 16px; height: 16px; border-radius: 50%;
  background: #fff; border: 3px solid var(--sega-blue);
}
.tl-dot.create { border-color: #1f9d57; }
.tl-dot.update { border-color: var(--sega-blue); }
.tl-dot.revert { border-color: #7e57c2; }
.tl-dot.delete { border-color: #c0392b; }
.tl-meta { font-size: .76rem; color: #7a8794; }
.tl-action { font-weight: 600; }
.tl-changes { font-size: .82rem; margin-top: .25rem; }
.tl-changes .chg-row { padding: 1px 0; }
.tl-changes .chg-da { color: #a5291b; text-decoration: line-through; opacity: .8; }
.tl-changes .chg-a  { color: #15693c; font-weight: 500; }

/* ===================== MISC ===================== */
.cursor-pointer { cursor: pointer; }
.text-mono { font-family: ui-monospace, SFMono-Regular, Menlo, monospace; font-size: .82rem; }
.leaflet-popup-content { margin: .6rem .8rem; }
.popup-title { font-weight: 600; margin-bottom: 2px; }
