:root {
  /* POLO brand palette */
  --bg:           #131722;
  --bg-elev:      #1B2030;
  --bg-elev-2:    #232a3d;
  --border:       #2A3045;
  --text:         #E2E8F0;
  --text-dim:     #94A3B8;
  --accent:       #6366F1;   /* indigo */
  --accent-hover: #7C7FF5;
  --accent-soft:  rgba(99,102,241,0.14);
  --green:        #10B981;
  --red:          #EF4444;
  --yellow:       #F59E0B;
  --radius:       12px;
  --shadow:       0 4px 18px rgba(0, 0, 0, 0.30);

  --font-sans: -apple-system, BlinkMacSystemFont, "Inter", "SF Pro Display", "Segoe UI", Roboto, sans-serif;
}

* { box-sizing: border-box; }

html, body {
  margin: 0;
  padding: 0;
  background: var(--bg);
  color: var(--text);
  font-family: -apple-system, BlinkMacSystemFont, "SF Pro Display", "Segoe UI", Roboto, sans-serif;
  font-size: 14px;
  line-height: 1.5;
}

.topbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 20px 32px;
  border-bottom: 1px solid var(--border);
  background: var(--bg-elev);
  position: sticky;
  top: 0;
  z-index: 50;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.25);
}

/* ---------- App shell (sidebar + main) ---------- */

.app-topbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 12px 24px;
  /* Rispetta il safe-area top: su iPhone in PWA standalone (viewport-fit=cover)
     senza questo la topbar finisce sotto il notch / dynamic island. */
  padding-top: max(12px, env(safe-area-inset-top));
  /* Safe-area orizzontali per landscape su iPhone con notch. */
  padding-left:  max(24px, env(safe-area-inset-left));
  padding-right: max(24px, env(safe-area-inset-right));
  background: var(--bg-elev);
  border-bottom: 1px solid var(--border);
  position: sticky;
  top: 0;
  z-index: 50;
  box-shadow: 0 4px 14px rgba(0,0,0,0.30);
}
.app-brand {
  display: flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  color: var(--text);
}
.app-logo {
  display: inline-flex;
  width: 32px; height: 32px;
  background: var(--accent);
  color: white;
  border-radius: 10px;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 14px rgba(99,102,241,0.30);
}
.app-title {
  font-weight: 700;
  font-size: 17px;
  letter-spacing: -0.01em;
}
.app-topbar-actions { display: flex; gap: 12px; align-items: center; }
.current-user { font-size: 12px; color: var(--text-dim); font-weight: 500; }
.btn-icon-action {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 30px;
  background: transparent;
  border: 1px solid var(--border);
  border-radius: 8px;
  color: var(--text-dim);
  cursor: pointer;
  padding: 0;
  transition: all 0.15s ease;
}
.btn-icon-action:hover { color: var(--text); border-color: var(--text-dim); background: var(--bg-elev-2); }
.btn-icon-action.btn-icon-danger:hover { color: var(--red); border-color: var(--red); }
td.actions .btn-icon-action { width: 26px; height: 26px; }

.app-shell {
  display: grid;
  grid-template-columns: 220px 1fr;
  min-height: calc(100vh - 57px);
}
.sidebar {
  background: var(--bg-elev);
  border-right: 1px solid var(--border);
  padding: 18px 10px;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.sidebar-link {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 12px;
  color: var(--text-dim);
  text-decoration: none;
  border-radius: 9px;
  font-size: 13px;
  font-weight: 500;
  transition: background 0.12s ease, color 0.12s ease;
}
.sidebar-link:hover { background: var(--bg-elev-2); color: var(--text); }
.sidebar-link.active {
  background: var(--accent-soft);
  color: var(--accent);
}
.sidebar-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
}

.section-content { padding: 24px 32px 64px; max-width: none; }
.section-content main, .section-content > main { max-width: none; padding: 0; }

/* Home: cap 1500px per non stirare l'hero su monitor molto larghi.
   width: 100% serve in grid cell: senza, `margin: 0 auto` disabilita
   lo stretching e il <main> si restringe al min-content. */
.section-content[data-section="home"] { width: 100%; max-width: 1500px; margin: 0 auto; }

/* Account: cap più stretto, così tutti i tab (Profilo, Sicurezza,
   Workspace) condividono la stessa larghezza percepita. */
.section-content[data-section="account"] { width: 100%; max-width: 1000px; margin: 0 auto; }

.section-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  margin-bottom: 24px;
  gap: 14px;
  flex-wrap: wrap;
}
.section-header h1 {
  margin: 0;
  font-size: 24px;
  font-weight: 700;
  letter-spacing: -0.01em;
}
.section-header .updated {
  display: block;
  margin-top: 4px;
  color: var(--text-dim);
  font-size: 12px;
}
.section-actions { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; }

/* Home — hero */
.home-hero {
  text-align: center;
  padding: 40px 24px 36px;
  margin-bottom: 40px;
  background: radial-gradient(ellipse at top, rgba(99,102,241,0.10) 0%, transparent 70%);
  border-radius: 18px;
}
.home-hero-logo {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 76px;
  height: 76px;
  background: var(--accent);
  color: white;
  border-radius: 20px;
  margin-bottom: 22px;
  box-shadow: 0 12px 36px rgba(99,102,241,0.40);
}
.home-hero-title {
  margin: 0 0 8px;
  font-size: 38px;
  font-weight: 700;
  letter-spacing: -0.025em;
  color: var(--text);
}
.home-hero-tag {
  color: var(--accent);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.20em;
  font-weight: 600;
  margin-bottom: 18px;
}
.home-hero-desc {
  max-width: 540px;
  margin: 0 auto 24px;
  font-size: 14.5px;
  line-height: 1.65;
  color: var(--text-dim);
}
.home-hero-welcome {
  font-size: 14px;
  color: var(--text);
  font-weight: 500;
}

.home-sections-label {
  font-size: 11px;
  color: var(--text-dim);
  text-transform: uppercase;
  letter-spacing: 0.10em;
  font-weight: 600;
  margin-bottom: 14px;
}

/* Home — card */
.home-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 16px;
}
.home-card {
  background: var(--bg-elev);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 22px;
  box-shadow: var(--shadow);
  text-decoration: none;
  color: var(--text);
  display: flex;
  flex-direction: column;
  gap: 14px;
  transition: border-color 0.15s ease, transform 0.1s ease, box-shadow 0.15s ease;
  min-height: 190px;
  position: relative;
}
.home-card:hover {
  border-color: var(--accent);
  transform: translateY(-2px);
  box-shadow: 0 12px 32px rgba(99,102,241,0.18);
}
.home-card-head {
  display: flex;
  align-items: center;
  gap: 12px;
}
.home-card-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  background: var(--accent-soft);
  color: var(--accent);
  border-radius: 10px;
}
.home-card-title { font-size: 15px; font-weight: 600; flex: 1; }
.home-card-arrow { color: var(--text-dim); display: inline-flex; }
.home-card:hover .home-card-arrow { color: var(--accent); }
.home-card-body { color: var(--text-dim); font-size: 13px; line-height: 1.5; }

.home-card-placeholder {
  opacity: 0.55;
  cursor: default;
  border-style: dashed;
}
.home-card-placeholder:hover {
  transform: none;
  border-color: var(--border);
  box-shadow: var(--shadow);
}
.home-card-placeholder .home-card-icon { background: var(--bg-elev-2); color: var(--text-dim); }

.widget-big { font-size: 22px; font-weight: 700; color: var(--text); margin-bottom: 4px; letter-spacing: -0.01em; }
.widget-row { display: flex; justify-content: space-between; font-size: 12.5px; margin: 3px 0; }
.widget-row .muted { color: var(--text-dim); }

.section-loading { opacity: 0.5; transition: opacity 0.2s ease; }
.error-state { padding: 40px; text-align: center; color: var(--red); }

@media (max-width: 900px) {
  .app-shell { grid-template-columns: 60px 1fr; }
  .sidebar-label { display: none; }
  .sidebar { padding: 12px 8px; }
  .sidebar-link { justify-content: center; }
  .section-content { padding: 16px 20px 40px; }
}

/* ---------- Mobile: sidebar → bottom tab bar (iOS-like) ---------- */
@media (max-width: 700px) {
  /* Topbar compatta (mantengo i safe-area override su top/sides) */
  .app-topbar {
    padding: 10px 14px;
    padding-top:   max(10px, env(safe-area-inset-top));
    padding-left:  max(14px, env(safe-area-inset-left));
    padding-right: max(14px, env(safe-area-inset-right));
  }
  .app-title { font-size: 15px; }
  .app-logo { width: 28px; height: 28px; }
  .current-user { display: none; }
  .workspace-switcher-name { max-width: 110px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
  .app-topbar-actions { gap: 8px; }

  /* Layout: una sola colonna, niente sidebar laterale */
  .app-shell { grid-template-columns: 1fr; }

  /* La sidebar diventa una bottom tab bar fissa */
  .sidebar {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    flex-direction: row;
    justify-content: space-around;
    align-items: stretch;
    gap: 0;
    padding: 6px 4px;
    padding-bottom: max(6px, env(safe-area-inset-bottom));
    border-right: none;
    border-top: 1px solid var(--border);
    background: var(--bg-elev);
    z-index: 50;
    box-shadow: 0 -4px 14px rgba(0,0,0,0.30);
  }
  .sidebar-link {
    flex: 1;
    min-width: 0;
    flex-direction: column;
    justify-content: center;
    gap: 0;
    padding: 10px 4px;
    border-radius: 8px;
  }
  .sidebar-label { display: none; }       /* solo icone, label superflue su iPhone */
  .sidebar-icon { width: 26px; height: 26px; }
  .sidebar-link.active { background: transparent; color: var(--accent); }
  .sidebar-link.active .sidebar-icon { transform: scale(1.08); }

  /* Padding-bottom al main per non finire dietro alla bottom bar */
  .section-content {
    padding: 12px 14px 96px;
  }
}

.brand h1 {
  margin: 0;
  font-size: 22px;
  font-weight: 600;
  letter-spacing: -0.01em;
}

.brand .updated {
  display: block;
  margin-top: 4px;
  color: var(--text-dim);
  font-size: 12px;
}

.topbar-actions { display: flex; gap: 10px; }

.btn-refresh, .btn-secondary, .btn-mini {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 18px;
  border: none;
  border-radius: var(--radius);
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.15s ease, transform 0.1s ease;
  font-family: inherit;
  text-decoration: none;
}

.btn-refresh { background: var(--accent); color: white; }
.btn-refresh:hover { background: var(--accent-hover); }
.btn-secondary {
  background: var(--bg-elev-2);
  color: var(--text);
  border: 1px solid var(--border);
  padding: 9px 14px;
}
.btn-secondary:hover { background: var(--border); }
.btn-mini {
  background: transparent;
  color: var(--text-dim);
  padding: 4px 10px;
  font-size: 12px;
  border: 1px solid var(--border);
}
.btn-mini:hover { background: var(--bg-elev-2); color: var(--text); }
.btn-mini.btn-danger { color: var(--red); border-color: rgba(239,68,68,0.35); }
.btn-mini.btn-danger:hover { background: rgba(239,68,68,0.10); }
.btn-icon-only {
  background: transparent;
  border: none;
  color: var(--text-dim);
  cursor: pointer;
  padding: 4px 8px;
  font-size: 14px;
}
.btn-icon-only:hover { color: var(--red); }

.btn-refresh:active, .btn-secondary:active { transform: scale(0.97); }
.btn-refresh:disabled, .btn-secondary:disabled { opacity: 0.6; cursor: progress; }
.btn-refresh.loading .btn-icon { animation: spin 1s linear infinite; }

@keyframes spin { to { transform: rotate(360deg); } }

main {
  margin: 0;
  padding: 24px 32px 64px;
}

.banner {
  background: rgba(245, 176, 65, 0.12);
  border: 1px solid var(--yellow);
  color: var(--yellow);
  padding: 14px 18px;
  border-radius: var(--radius);
  margin-bottom: 20px;
  font-size: 13px;
}

.banner-warn {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  background: rgba(245, 176, 65, 0.10);
  border: 1px solid var(--yellow);
  color: var(--yellow);
  padding: 12px 16px;
  border-radius: var(--radius);
  margin-bottom: 18px;
  font-size: 13px;
}
.banner-warn strong { color: var(--text); }
.banner-warn .btn-mini {
  background: var(--yellow);
  color: var(--bg);
  border: none;
}
.banner-warn .btn-mini:hover { background: #d99a3a; }
.banner.hidden { display: none; }
.banner strong { color: var(--text); }
.banner a {
  color: var(--accent);
  text-decoration: none;
  margin-left: 8px;
  font-weight: 600;
}
.banner a:hover { text-decoration: underline; }

/* 4 colonne di default → 8 card si dispongono naturalmente su 2 righe da 4
   con numeri ampi e leggibili. */
.cards {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
  margin-bottom: 24px;
}
@media (max-width: 1000px) {
  .cards { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 700px) {
  .cards { grid-template-columns: repeat(2, 1fr); }
}

.card {
  background: var(--bg-elev);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 14px 14px;
  box-shadow: var(--shadow);
  min-width: 0; /* permette al grid di stringere le card senza overflow */
}

.card-label {
  color: var(--text-dim);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin-bottom: 8px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 6px;
}
.card-label .risk-pill {
  text-transform: none;
  letter-spacing: 0;
  font-size: 11px;
  padding: 2px 8px;
}

/* Ridotti per accomodare 7 card su una riga con numeri tipo "186.204,24 €". */
.card-value { font-size: 18px; font-weight: 700; letter-spacing: -0.01em; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.card-value.small { font-size: 16px; }
.card-sub { color: var(--text-dim); font-size: 11px; margin-top: 4px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.card.highlight { border-color: var(--accent); background: linear-gradient(180deg, rgba(79,140,255,0.08), var(--bg-elev)); }

.editable-card { cursor: pointer; transition: border-color 120ms ease, background 120ms ease; }
.editable-card:hover { border-color: var(--text-dim); background: rgba(255,255,255,0.02); }
.edit-hint { color: var(--text-dim); font-size: 12px; opacity: 0.55; }
.editable-card:hover .edit-hint { opacity: 1; }

.charts {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr;
  gap: 14px;
  margin-bottom: 24px;
}
.chart-wide { grid-column: 1; grid-row: 1; }

.chart-box {
  background: var(--bg-elev);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 18px;
  box-shadow: var(--shadow);
  min-height: 300px;
  display: flex;
  flex-direction: column;
}

.chart-box h2 {
  margin: 0 0 14px;
  font-size: 13px;
  font-weight: 600;
  color: var(--text-dim);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  flex-shrink: 0;
}
.chart-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 6px;
  flex-shrink: 0;
}
.chart-head h2 { margin: 0; }
.chart-box > canvas {
  flex: 1 1 0;
  width: 100%;
  min-height: 220px;
}

.period-pl {
  display: flex;
  align-items: baseline;
  gap: 10px;
  margin: 2px 0 8px;
  font-size: 12px;
  color: var(--text-dim);
  flex-wrap: wrap;
}
.period-pl .label { font-weight: 600; }
.period-pl .abs, .period-pl .pct { font-weight: 700; font-variant-numeric: tabular-nums; }
.period-pl .abs.profit, .period-pl .pct.profit { color: var(--green); }
.period-pl .abs.loss,   .period-pl .pct.loss   { color: var(--red); }
.period-pl .range-meta { margin-left: auto; font-size: 11px; opacity: 0.75; }

.range-pills { display: flex; gap: 4px; }
.range-pills button {
  background: transparent;
  border: 1px solid var(--border);
  color: var(--text-dim);
  padding: 4px 10px;
  font-size: 11px;
  font-weight: 600;
  border-radius: 6px;
  cursor: pointer;
  font-family: inherit;
}
.range-pills button:hover { color: var(--text); border-color: var(--text-dim); }
.range-pills button.active {
  background: var(--accent);
  border-color: var(--accent);
  color: white;
}

/* canvas height ora gestita da flex (chart-box > canvas) */

.section-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 14px;
}

.section-head h2 {
  margin: 0;
  font-size: 13px;
  font-weight: 600;
  color: var(--text-dim);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.periods-section {
  margin-top: 18px;
  padding-top: 14px;
  border-top: 1px solid var(--border);
}
.periods-section h3 {
  margin: 0 0 12px;
  font-size: 11px;
  font-weight: 600;
  color: var(--text-dim);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.periods-section h3 .hint { font-weight: 400; text-transform: none; letter-spacing: 0; }
.periods-grid {
  display: grid;
  grid-template-columns: repeat(10, 1fr);
  gap: 8px;
}
@media (max-width: 1200px) { .periods-grid { grid-template-columns: repeat(5, 1fr); } }
@media (max-width: 700px)  { .periods-grid { grid-template-columns: repeat(3, 1fr); } }
.period-tile {
  background: var(--bg-elev-2);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 10px 8px;
  text-align: center;
}
.period-tile .label {
  font-size: 10px;
  color: var(--text-dim);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.period-tile .pct {
  font-size: 15px;
  font-weight: 700;
  margin-top: 4px;
  font-variant-numeric: tabular-nums;
}
.period-tile .eur {
  font-size: 11px;
  color: var(--text-dim);
  margin-top: 2px;
  font-variant-numeric: tabular-nums;
}

.table-box, .news-box, .assets-box, .closed-positions-box, .movements-box {
  background: var(--bg-elev);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 18px;
  box-shadow: var(--shadow);
  margin-bottom: 18px;
}
.closed-positions-box.hidden, .movements-box.hidden { display: none; }
.closed-positions-table .asset-name,
.movements-table .asset-name { font-weight: 600; color: var(--text); }
.closed-positions-table .asset-isin,
.movements-table .asset-isin { font-size: 11px; color: var(--text-dim); margin-top: 2px; }
.op-badge {
  display: inline-block;
  padding: 3px 8px;
  border-radius: 6px;
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

/* Badge P&L colorato (in tabella posizioni chiuse) */
.pl-badge {
  display: inline-block;
  padding: 3px 8px;
  border-radius: 6px;
  font-weight: 600;
  font-size: 12px;
  letter-spacing: 0.01em;
}
.pl-badge.profit { background: rgba(16,185,129,0.14);  color: var(--green); }
.pl-badge.loss   { background: rgba(239,68,68,0.14);   color: var(--red);   }

/* Badge portafoglio (Nostro / Bambine) */
.pf-badge {
  display: inline-block;
  padding: 2px 9px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.02em;
}
.pf-badge.pf-nostro  { background: var(--accent-soft);                color: var(--accent); }
.pf-badge.pf-bambine { background: rgba(245,158,11,0.16);             color: var(--yellow); }

/* Sezioni collassabili (Tutti i movimenti) */
.collapsible-head {
  display: flex;
  align-items: center;
  gap: 12px;
  width: 100%;
  background: transparent;
  border: none;
  padding: 0;
  text-align: left;
  color: inherit;
  cursor: pointer;
  font-family: inherit;
}
.collapsible-head h2 { margin: 0; }
.collapsible-chevron {
  display: inline-block;
  font-size: 12px;
  color: var(--text-dim);
  transition: transform 0.18s ease;
  width: 14px;
}
.movements-box:not(.collapsed) .collapsible-chevron,
.closed-positions-box:not(.collapsed) .collapsible-chevron {
  transform: rotate(90deg);
}
.collapsible-body {
  overflow: hidden;
  transition: opacity 0.18s ease;
}
.movements-box.collapsed .collapsible-body,
.closed-positions-box.collapsed .collapsible-body {
  display: none;
}

.stale-banner {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 14px;
  background: rgba(245,158,11,0.10);
  border: 1px solid var(--yellow);
  border-radius: 10px;
  color: var(--yellow);
  font-size: 13px;
  margin-bottom: 14px;
}
.stale-banner.hidden { display: none; }
.stale-marker {
  display: inline-block;
  margin-left: 6px;
  color: var(--yellow);
  font-size: 11px;
  font-weight: 600;
  cursor: help;
}

.table-wrapper { overflow-x: auto; }

table {
  width: 100%;
  border-collapse: collapse;
  font-size: 12.5px;
}

th, td {
  padding: 9px 10px;
  text-align: left;
  border-bottom: 1px solid var(--border);
  white-space: nowrap;
}

th {
  color: var(--text-dim);
  font-weight: 500;
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  background: var(--bg-elev-2);
  position: sticky;
  top: 0;
}
th[data-sort] { cursor: pointer; user-select: none; }
th[data-sort]:hover { color: var(--text); }
th[data-sort]::after {
  content: '';
  display: inline-block;
  margin-left: 4px;
  opacity: 0.3;
  border-left: 3px solid transparent;
  border-right: 3px solid transparent;
  border-bottom: 4px solid currentColor;
  vertical-align: middle;
}
th[data-sort].sort-asc::after { opacity: 1; }
th[data-sort].sort-desc::after { opacity: 1; transform: rotate(180deg); }

td.num, th.num { text-align: right; font-variant-numeric: tabular-nums; }
tbody tr:hover { background: var(--bg-elev-2); }

.pos { color: var(--green); font-weight: 600; }
.neg { color: var(--red); font-weight: 600; }
.zero { color: var(--text-dim); }

tbody tr.pending { opacity: 0.55; }
tbody tr.pending td.actions { opacity: 1; }
.badge-pending {
  display: inline-block;
  padding: 1px 7px;
  background: rgba(245,176,65,0.18);
  color: var(--yellow);
  border-radius: 999px;
  font-size: 10px;
  font-weight: 600;
  margin-left: 6px;
}

td.actions { white-space: nowrap; }
td.actions button { padding: 2px 6px; margin-left: 2px; }

.section-head .actions { display: flex; gap: 8px; }

.drop-overlay {
  position: fixed;
  inset: 0;
  background: rgba(79,140,255,0.18);
  border: 4px dashed var(--accent);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 200;
  pointer-events: none;
}
.drop-overlay.hidden { display: none; }
.drop-message {
  background: var(--bg-elev);
  padding: 24px 36px;
  border-radius: var(--radius);
  border: 1px solid var(--accent);
  text-align: center;
  color: var(--text);
  font-size: 14px;
  font-weight: 500;
}
.drop-icon { font-size: 32px; margin-bottom: 8px; color: var(--accent); }

.isin { font-family: "SF Mono", Menlo, Consolas, monospace; font-size: 11.5px; color: var(--text-dim); }

.risk-pill {
  display: inline-block;
  padding: 2px 7px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 700;
  background: var(--bg-elev-2);
  color: var(--text);
}
.risk-1, .risk-2 { background: rgba(46, 204, 113, 0.18); color: var(--green); }
.risk-3, .risk-4 { background: rgba(245, 176, 65, 0.18); color: var(--yellow); }
.risk-5, .risk-6, .risk-7 { background: rgba(255, 92, 92, 0.18); color: var(--red); }

.pf-pill {
  display: inline-block;
  padding: 2px 9px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.02em;
  border: 1px solid transparent;
}
.pf-nostro { background: rgba(79, 140, 255, 0.18); color: #6ba1ff; border-color: rgba(79,140,255,0.4); }
.pf-bambine { background: rgba(231, 121, 198, 0.18); color: #e779c6; border-color: rgba(231,121,198,0.45); }
.pf-other { background: var(--bg-elev-2); color: var(--text); border-color: var(--border); }

.news-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 12px;
}
.news-card {
  background: var(--bg-elev-2);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 14px 16px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  transition: border-color 0.15s ease, transform 0.1s ease;
  min-height: 100px;
}
.news-card:hover { border-color: var(--accent); transform: translateY(-1px); }
.news-card .source {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--accent);
  font-weight: 700;
}
.news-card a.title {
  color: var(--text);
  text-decoration: none;
  font-weight: 600;
  font-size: 13px;
  line-height: 1.35;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.news-card a.title:hover { color: var(--accent); }
.news-card .summary {
  color: var(--text-dim);
  font-size: 11.5px;
  line-height: 1.4;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.news-card .date {
  color: var(--text-dim);
  font-size: 10.5px;
  margin-top: auto;
}
.news-grid .muted { color: var(--text-dim); grid-column: 1 / -1; }

.assets-panel.hidden { display: none; }

.assets-table { font-size: 12px; }
.assets-table td.url-cell {
  max-width: 380px;
  overflow: hidden;
  text-overflow: ellipsis;
  font-family: "SF Mono", Menlo, Consolas, monospace;
  font-size: 11px;
  color: var(--text-dim);
}
.assets-table .source-pill {
  display: inline-block;
  padding: 2px 8px;
  background: var(--bg-elev-2);
  color: var(--text);
  border-radius: 999px;
  font-size: 11px;
}

.asset-form {
  background: var(--bg-elev-2);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 18px;
  margin-top: 16px;
}

.asset-form h3 {
  margin: 0 0 12px;
  font-size: 13px;
  font-weight: 600;
  color: var(--text-dim);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.form-row { display: flex; gap: 12px; }
.form-row label, .asset-form > label {
  display: block;
  margin-bottom: 10px;
  font-size: 12px;
  color: var(--text-dim);
  flex: 1;
}

.asset-form input, .asset-form select {
  display: block;
  width: 100%;
  margin-top: 4px;
  padding: 9px 12px;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 8px;
  color: var(--text);
  font-size: 13px;
  font-family: inherit;
}

.asset-form input:focus, .asset-form select:focus {
  outline: none;
  border-color: var(--accent);
}

.form-actions { display: flex; gap: 10px; margin-top: 8px; }

.dual-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
  margin-bottom: 18px;
}
@media (max-width: 1200px) {
  .dual-row { grid-template-columns: 1fr; gap: 0; }
}

.row-top {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
  margin-bottom: 18px;
}
.row-mid {
  display: grid;
  grid-template-columns: 1.5fr 1fr 1fr;
  gap: 18px;
  margin-bottom: 18px;
}
@media (max-width: 1200px) {
  .row-top { grid-template-columns: 1fr; }
  .row-mid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 800px) {
  .row-mid { grid-template-columns: 1fr; }
}

.row-top .chart-box, .row-top .projection-box,
.row-mid .chart-box, .row-mid .allocation-box, .row-mid .projection-box { margin-bottom: 0; }

/* Donut e treemap hanno bisogno di più altezza per restare proporzionati */
.row-mid .chart-box, .row-mid .allocation-box { min-height: 380px; }

.allocation-box, .projection-box {
  background: var(--bg-elev);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 18px;
  box-shadow: var(--shadow);
  margin-bottom: 18px;
}

.dual-row .allocation-box, .dual-row .projection-box { margin-bottom: 0; }

.allocation-bars { display: flex; flex-direction: column; gap: 10px; }
.alloc-row { display: grid; grid-template-columns: 130px 1fr 140px; gap: 12px; align-items: center; }
.alloc-row .alloc-label { font-size: 13px; color: var(--text); font-weight: 500; }
.alloc-row .alloc-bar {
  position: relative;
  height: 22px;
  background: var(--bg-elev-2);
  border-radius: 6px;
  overflow: hidden;
}
.alloc-row .alloc-fill {
  height: 100%;
  border-radius: 6px;
  transition: width 0.4s ease;
}
.alloc-row .alloc-target {
  position: absolute;
  top: -3px;
  bottom: -3px;
  width: 2px;
  background: var(--text);
  opacity: 0.6;
}
.alloc-row .alloc-stats { font-size: 12px; color: var(--text-dim); text-align: right; }
.alloc-row .alloc-stats strong { color: var(--text); }
.alloc-row .delta { margin-left: 6px; font-weight: 600; }
.alloc-row .delta.pos { color: var(--green); }
.alloc-row .delta.neg { color: var(--red); }

.rebalance-hint {
  margin-top: 14px;
  padding: 12px 14px;
  background: rgba(245, 176, 65, 0.08);
  border: 1px solid var(--yellow);
  border-radius: 8px;
  color: var(--yellow);
  font-size: 12px;
}
.rebalance-hint.hidden { display: none; }
.rebalance-hint strong { color: var(--text); }

.targets-form { margin-top: 14px; padding: 14px; background: var(--bg-elev-2); border-radius: var(--radius); }
.targets-form.hidden { display: none; }
.targets-form .form-row { gap: 10px; }
.targets-form input { width: 100%; padding: 8px 10px; background: var(--bg); border: 1px solid var(--border); border-radius: 6px; color: var(--text); font-size: 13px; }

.pac-summary { margin-bottom: 14px; }

.proj-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;
  margin-bottom: 12px;
}
.proj-stat {
  background: var(--bg-elev-2);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 9px 10px;
  min-width: 0;
}
.proj-stat-label {
  font-size: 10px;
  color: var(--text-dim);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-weight: 600;
  margin-bottom: 4px;
}
.proj-stat-value {
  font-size: 15px;
  font-weight: 700;
  color: var(--text);
  font-variant-numeric: tabular-nums;
}
.proj-stat-unit {
  font-weight: 400;
  font-size: 11px;
  color: var(--text-dim);
  margin-left: 2px;
}

.pac-chips { display: flex; flex-wrap: wrap; gap: 6px; }
.pac-chip {
  padding: 3px 10px;
  background: var(--accent-soft);
  color: var(--accent);
  border-radius: 999px;
  font-size: 11px;
  font-weight: 600;
  font-variant-numeric: tabular-nums;
}

/* Nasconde gli spinner ai number input (Webkit + Firefox) */
input[type="number"]::-webkit-inner-spin-button,
input[type="number"]::-webkit-outer-spin-button {
  -webkit-appearance: none;
  margin: 0;
}
input[type="number"] { -moz-appearance: textfield; appearance: textfield; }

#projectionChart { max-height: 320px; }

.projection-controls { display: flex; gap: 12px; align-items: center; }
.control-inline { display: flex; gap: 6px; align-items: center; font-size: 12px; color: var(--text-dim); }
.num-input {
  width: 64px;
  padding: 6px 8px;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 6px;
  color: var(--text);
  font-size: 13px;
  font-family: inherit;
  text-align: right;
}
.num-input:focus { outline: none; border-color: var(--accent); }

.select-pill {
  background: var(--bg-elev-2);
  color: var(--text);
  border: 1px solid var(--border);
  padding: 9px 14px;
  border-radius: var(--radius);
  font-size: 13px;
  font-family: inherit;
  font-weight: 500;
}
.select-pill:focus { outline: none; border-color: var(--accent); }

.hint { color: var(--text-dim); font-size: 11px; font-weight: 400; margin-left: 6px; }

.subsection-title {
  margin: 20px 0 10px;
  font-size: 12px;
  font-weight: 600;
  color: var(--text-dim);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.upload-area {
  background: var(--bg-elev-2);
  border: 1px dashed var(--border);
  border-radius: var(--radius);
  padding: 18px;
  margin-bottom: 8px;
}
.upload-area.dragover { border-color: var(--accent); background: rgba(79,140,255,0.06); }
.upload-content strong { display: block; margin-bottom: 8px; }
.upload-content { color: var(--text-dim); font-size: 13px; }
.upload-content strong { color: var(--text); }
.upload-controls { display: flex; gap: 12px; align-items: center; margin-top: 10px; flex-wrap: wrap; }
.upload-label { display: flex; gap: 6px; align-items: center; color: var(--text-dim); font-size: 12px; }
.upload-label select {
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 6px 10px;
  color: var(--text);
}
.muted { color: var(--text-dim); font-size: 12px; }

.modal {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.6);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 100;
  padding: 24px;
}
.modal.hidden { display: none; }
.modal-content {
  background: var(--bg-elev);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  max-width: 1100px;
  width: 100%;
  max-height: 90vh;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  box-shadow: 0 20px 50px rgba(0,0,0,0.5);
}
.modal-content.modal-narrow { max-width: 560px; }
.modal-content.modal-wide { max-width: 1100px; }
.modal-content .asset-form { padding: 20px 22px; overflow: auto; }
.modal-body { padding: 18px 22px; overflow: auto; }

.detail-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 14px;
  font-size: 12px;
  color: var(--text-dim);
  margin-bottom: 4px;
}
.detail-meta strong { color: var(--text); }
.detail-meta .meta-link { color: var(--accent); text-decoration: none; }
.detail-meta .meta-link:hover { text-decoration: underline; }

.detail-cards {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 12px;
  margin: 14px 0;
}
@media (max-width: 1000px) { .detail-cards { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 600px)  { .detail-cards { grid-template-columns: repeat(2, 1fr); } }
.detail-cards .card { padding: 14px; }
.detail-cards .card-value { font-size: 18px; }

.detail-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  margin-bottom: 14px;
}
@media (max-width: 800px) {
  .detail-grid { grid-template-columns: 1fr; }
  .detail-cards { grid-template-columns: repeat(2, 1fr); }
}
.detail-box {
  background: var(--bg-elev-2);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 14px;
  margin-bottom: 14px;
}
.detail-box h3 {
  margin: 0 0 10px;
  font-size: 11px;
  font-weight: 600;
  color: var(--text-dim);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.detail-box canvas { max-height: 220px; }

.detail-table {
  width: 100%;
  font-size: 12px;
  border-collapse: collapse;
}
.detail-table td {
  padding: 5px 0;
  border-bottom: 1px solid var(--border);
  color: var(--text);
}
.detail-table td:first-child { color: var(--text-dim); width: 50%; }
.detail-table tr:last-child td { border-bottom: none; }

.detail-table-mov {
  width: 100%;
  font-size: 12px;
  border-collapse: collapse;
}
.detail-table-mov th, .detail-table-mov td {
  padding: 6px 10px;
  border-bottom: 1px solid var(--border);
  text-align: left;
}
.detail-table-mov th { color: var(--text-dim); font-size: 10px; text-transform: uppercase; }
.detail-table-mov td.num, .detail-table-mov th.num { text-align: right; font-variant-numeric: tabular-nums; }

.fund-cell .fund-desc { display: block; color: var(--text); font-weight: 500; }
.fund-cell .fund-isin { display: block; color: var(--text-dim); font-size: 10px; font-family: "SF Mono", Menlo, monospace; margin-top: 2px; }
.modal-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 18px 22px;
  border-bottom: 1px solid var(--border);
}
.modal-head h2 { margin: 0; font-size: 16px; }
.modal-close {
  background: none; border: none; color: var(--text-dim);
  font-size: 18px; cursor: pointer;
}
.modal-close:hover { color: var(--text); }
.modal-summary {
  padding: 16px 22px;
  display: flex; gap: 28px;
  background: var(--bg-elev-2);
  font-size: 13px;
}
.modal-summary div strong { color: var(--text); margin-left: 6px; }
.modal-summary div { color: var(--text-dim); }
.modal-warning {
  margin: 12px 22px;
  padding: 12px 16px;
  background: rgba(245, 176, 65, 0.08);
  border: 1px solid var(--yellow);
  color: var(--yellow);
  border-radius: 8px;
  font-size: 12px;
}
.modal-warning.hidden { display: none; }
.modal-content .table-wrapper { flex: 1; overflow: auto; padding: 0 22px; }
.modal-actions {
  display: flex; gap: 10px; justify-content: flex-end;
  padding: 16px 22px;
  border-top: 1px solid var(--border);
}

/* Semaforo P&L riusabile (verde/rosso) per card-value */
.card-value.profit { color: var(--green); }
.card-value.loss   { color: var(--red); }

/* Allegati — lista compatta dentro il modal di un'entità */
.allegato-row {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 10px; margin-bottom: 6px;
  background: var(--bg-elev-2); border-radius: 6px;
}
.allegato-name {
  flex: 1; min-width: 0;
  display: inline-flex; align-items: center; gap: 8px;
  color: var(--text); font-size: 13px; text-decoration: none;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.allegato-name:hover { color: var(--accent); }

/* Veicoli — dot badge per stato scadenza */
.veh-dot {
  display: inline-block; margin-left: 6px;
  padding: 1px 7px; border-radius: 999px;
  border: 1px solid var(--border); color: var(--text-dim);
  font-size: 10.5px; font-weight: 500; white-space: nowrap;
}
.veh-dot.badge-soon    { color: var(--yellow); border-color: rgba(245,176,65,0.35); }
.veh-dot.badge-today   { color: var(--accent); border-color: var(--accent); background: var(--accent-soft); }
.veh-dot.badge-overdue { color: var(--red); border-color: rgba(239,68,68,0.35); background: rgba(239,68,68,0.10); }

/* Veicoli — griglia di card cliccabili */
.veh-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 12px;
  margin-bottom: 24px;
}
.veh-card {
  background: var(--bg-elev); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 14px 16px;
  cursor: pointer; text-align: left; font: inherit; color: inherit;
  transition: border-color 120ms, transform 80ms;
  display: block; width: 100%;
}
.veh-card:hover { border-color: var(--accent); }
.veh-card:active { transform: scale(0.99); }
.veh-card.empty { cursor: default; }
.veh-card.empty:hover { border-color: var(--border); }

.veh-card-head { display: flex; align-items: center; gap: 8px; }
.veh-card-targa {
  font-weight: 700; font-size: 17px; color: var(--text);
  letter-spacing: 1px; font-variant-numeric: tabular-nums;
}
.veh-card-pill {
  background: var(--bg-elev-2); color: var(--text-dim);
  padding: 2px 8px; border-radius: 999px; font-size: 10.5px;
  text-transform: capitalize; font-weight: 500;
}
.veh-card-desc { color: var(--text); font-size: 13px; margin-top: 4px; }
.veh-card-meta {
  display: flex; justify-content: space-between; align-items: center;
  margin-top: 10px; padding-top: 10px;
  border-top: 1px solid var(--border);
  font-size: 12px; gap: 8px; flex-wrap: wrap;
}
.veh-card-next { color: var(--text); font-weight: 500; }

/* Documenti — usa min-width più ampio nella grid per le badge orizzontali */
.section-content[data-section="documenti"] .veh-grid {
  grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
  gap: 14px;
}

/* Documenti — lista familiari in stile "badge" (avatar + dettagli) */
.fam-badge {
  display: flex; gap: 14px; align-items: stretch;
  background: var(--bg-elev);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 14px 16px;
  text-align: left;
  cursor: pointer; font: inherit; color: inherit;
  transition: border-color 120ms, transform 80ms, box-shadow 120ms;
  position: relative; overflow: hidden;
}
.fam-badge:hover {
  border-color: var(--accent);
  box-shadow: 0 4px 14px rgba(99,102,241,0.10);
}
.fam-badge:active { transform: scale(0.99); }
.fam-badge.empty { cursor: default; border-style: dashed; }
.fam-badge.empty:hover { border-color: var(--border); box-shadow: none; }

/* striscia colorata laterale sinistra come una tessera */
.fam-badge::before {
  content: ''; position: absolute; left: 0; top: 0; bottom: 0;
  width: 4px; background: var(--accent);
}

.fam-avatar {
  width: 56px; height: 56px; border-radius: 14px;
  background: linear-gradient(135deg, var(--accent), var(--accent-hover, #4f46e5));
  color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-weight: 700; font-size: 20px; letter-spacing: 0.5px;
  flex-shrink: 0;
  box-shadow: 0 4px 10px rgba(99,102,241,0.30);
}

.fam-info { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 6px; }
.fam-info-top { display: flex; align-items: baseline; gap: 8px; flex-wrap: wrap; }
.fam-name {
  color: var(--text); font-size: 16px; font-weight: 700; line-height: 1.2;
}
.fam-rel {
  font-size: 10px; font-weight: 600; letter-spacing: 0.06em;
  text-transform: uppercase; color: var(--accent);
  background: var(--accent-soft); padding: 2px 8px; border-radius: 999px;
}

.fam-meta { display: flex; flex-wrap: wrap; gap: 6px; }
.fam-pill {
  background: var(--bg-elev-2); border: 1px solid var(--border);
  padding: 2px 8px; border-radius: 999px;
  font-size: 11px; color: var(--text-dim);
  white-space: nowrap;
}
.fam-pill.mono { font-family: "SF Mono", Menlo, Consolas, monospace; letter-spacing: 0.04em; }

.fam-tipi { display: flex; flex-wrap: wrap; gap: 4px; margin-top: 2px; }
.fam-tipo {
  background: transparent; border: 1px solid var(--border);
  color: var(--text-dim);
  font-size: 10.5px; padding: 1px 7px; border-radius: 4px;
}

.fam-next {
  font-size: 12px; color: var(--text);
  padding-top: 8px; margin-top: auto;
  border-top: 1px dashed var(--border);
}
.fam-next strong { color: var(--text); font-weight: 600; }

/* Documenti — testa del modal familiare come "tessera" personale */
.person-card {
  display: flex; gap: 14px; align-items: center;
  background: linear-gradient(135deg, var(--accent-soft), var(--bg-elev-2));
  border: 1px solid var(--border);
  border-radius: 12px; padding: 14px 16px;
  margin-bottom: 6px;
}
.person-avatar {
  width: 56px; height: 56px; border-radius: 50%;
  background: var(--accent); color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-weight: 700; font-size: 20px; letter-spacing: 0.5px;
  flex-shrink: 0;
}
.person-info { flex: 1; min-width: 0; }
.person-name { color: var(--text); font-size: 17px; font-weight: 700; line-height: 1.2; }
.person-rel  {
  display: inline-block; margin-top: 4px;
  color: var(--accent); font-size: 11px; font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.06em;
}
.person-meta {
  display: flex; flex-wrap: wrap; gap: 6px; margin-top: 10px;
}
.person-pill {
  display: inline-flex; align-items: center; gap: 4px;
  background: var(--bg-elev); border: 1px solid var(--border);
  padding: 3px 10px; border-radius: 999px;
  font-size: 11px; color: var(--text);
  white-space: nowrap;
}
.person-pill.cf {
  font-family: "SF Mono", Menlo, Consolas, monospace;
  font-size: 11px; letter-spacing: 0.04em;
  color: var(--text-dim);
}

/* Veicoli — show modal layout */
.veh-show-grid {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 16px; padding: 4px 0 10px;
}
.veh-show-cell { display: flex; flex-direction: column; gap: 2px; }
.veh-show-label { color: var(--text-dim); font-size: 11px; text-transform: uppercase; letter-spacing: 0.05em; }
.veh-show-value { color: var(--text); font-size: 14px; font-weight: 500; }
.veh-show-sec {
  margin: 18px 0 8px; font-size: 12px; font-weight: 600;
  color: var(--text-dim); text-transform: uppercase; letter-spacing: 0.06em;
}
.veh-show-scad {
  display: flex; flex-direction: column;
  border: 1px solid var(--border); border-radius: 10px; overflow: hidden;
}
.veh-show-scad-row {
  display: grid; grid-template-columns: 110px 90px 1fr auto;
  align-items: center; gap: 12px; padding: 10px 14px;
  border-bottom: 1px solid var(--border);
  font-size: 13px;
}
.veh-show-scad-row:last-child { border-bottom: none; }
.veh-show-scad-label { color: var(--text); font-weight: 500; }
.veh-show-scad-date { color: var(--text); font-variant-numeric: tabular-nums; }
.veh-show-scad-cost { color: var(--text-dim); font-size: 12px; text-align: right; }
.veh-show-scad-extra { grid-column: 2 / -1; color: var(--text-dim); font-size: 11px; margin-top: -4px; }
.veh-show-notes { color: var(--text-dim); font-size: 13px; white-space: pre-wrap; }
@media (max-width: 700px) {
  .veh-show-grid { grid-template-columns: 1fr; }
  .veh-show-scad-row { grid-template-columns: 1fr; gap: 4px; }
  .veh-show-scad-cost { text-align: left; }
}

/* Home — widget "Scadenze prossimi 30 giorni" */
.home-upcoming {
  background: var(--bg-elev);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 16px 18px;
  margin-bottom: 22px;
  box-shadow: var(--shadow);
}
.home-upcoming.hidden { display: none; }
.home-upcoming-head { display: flex; justify-content: space-between; align-items: flex-start; gap: 12px; margin-bottom: 10px; }
.home-upcoming-title { margin: 0 0 2px; font-size: 14px; font-weight: 600; }
.home-upcoming-sub { color: var(--text-dim); font-size: 12px; }
.home-upcoming-count {
  background: var(--accent-soft); color: var(--accent);
  padding: 4px 12px; border-radius: 999px; font-weight: 700; font-size: 13px;
}
.home-upcoming-list { display: flex; flex-direction: column; gap: 6px; margin-top: 8px; }
.upcoming-row {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 10px; border-radius: 8px; background: var(--bg-elev-2);
}
.upcoming-main { flex: 1; min-width: 0; }
.upcoming-title { color: var(--text); font-size: 13px; font-weight: 500; }
.upcoming-meta { color: var(--text-dim); font-size: 11px; margin-top: 2px; text-transform: capitalize; }
.upcoming-amt { color: var(--text-dim); font-size: 12px; font-variant-numeric: tabular-nums; }
.upcoming-badge {
  background: var(--bg-elev); border: 1px solid var(--border);
  padding: 2px 8px; border-radius: 999px; font-size: 11px; color: var(--text-dim);
  white-space: nowrap;
}
.upcoming-badge.soon     { color: var(--yellow); border-color: rgba(245,176,65,0.35); }
.upcoming-badge.today    { color: var(--accent); border-color: var(--accent); background: var(--accent-soft); }
.upcoming-badge.overdue  { color: var(--red); border-color: rgba(239,68,68,0.35); background: rgba(239,68,68,0.10); }

/* Riga "Totale" in fondo alle tabelle di dettaglio */
tr.total-row td {
  background: var(--bg-elev-2);
  border-top: 1px solid var(--text-dim);
  border-bottom: none;
}
tr.total-row td.num.profit strong { color: var(--green); }
td.num.profit { color: var(--green); }

/* Marker visivo per valori stimati (vs reali) nelle tabelle di dettaglio */
td.estimate, .estimate {
  font-style: italic;
  color: var(--text-dim);
}
td.estimate.profit { color: rgba(80, 200, 120, 0.7); }
.estimate-marker {
  display: inline-block;
  margin-right: 2px;
  opacity: 0.6;
  font-style: normal;
  font-weight: 700;
}
.estimate-legend { margin-left: auto; font-size: 11px; color: var(--text-dim); }
.estimate-legend .estimate-marker { margin-right: 4px; }

/* Cella editabile "Bolletta reale" */
.bill-real-cell {
  cursor: pointer;
  transition: background 120ms ease;
}
.bill-real-cell:hover { background: rgba(79,140,255,0.08); }
.bill-real-cell.has-value { color: var(--text); font-weight: 600; }
.bill-real-amount { color: var(--text); }
.bill-real-input {
  width: 100%;
  background: var(--bg-elev);
  border: 1px solid var(--accent);
  border-radius: 4px;
  padding: 4px 8px;
  color: var(--text);
  font-family: inherit;
  font-size: 12.5px;
  text-align: right;
  font-variant-numeric: tabular-nums;
}
.bill-real-input:focus { outline: none; border-color: var(--accent-hover); }


/* asset-form: textarea adattato allo stile delle input */
.asset-form textarea {
  background: var(--bg-elev-2);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 8px 10px;
  color: var(--text);
  font-family: inherit;
  font-size: 13px;
  resize: vertical;
}
.asset-form textarea:focus { outline: none; border-color: var(--accent); }

/* Confirm dialog styled */
.confirm-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.62);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 300;
  padding: 20px;
  backdrop-filter: blur(3px);
}
.confirm-overlay.hidden { display: none; }

.confirm-box {
  background: var(--bg-elev);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 24px;
  max-width: 400px;
  width: 100%;
  box-shadow: 0 24px 60px rgba(0,0,0,0.5);
  text-align: center;
  animation: confirm-pop 0.18s ease-out;
}
@keyframes confirm-pop {
  from { transform: scale(0.95); opacity: 0; }
  to   { transform: scale(1);    opacity: 1; }
}

.confirm-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  border-radius: 14px;
  margin-bottom: 14px;
}
.confirm-icon-default {
  background: var(--accent-soft);
  color: var(--accent);
}
.confirm-icon-danger {
  background: rgba(239,68,68,0.14);
  color: var(--red);
}

.confirm-box h2 {
  margin: 0 0 8px;
  font-size: 17px;
  font-weight: 600;
  color: var(--text);
}
.confirm-message {
  margin: 0 0 22px;
  color: var(--text-dim);
  font-size: 14px;
  line-height: 1.5;
}

.confirm-actions {
  display: flex;
  gap: 10px;
  justify-content: center;
}
.confirm-actions button {
  min-width: 110px;
  padding: 10px 18px;
  border-radius: 9px;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  font-family: inherit;
  transition: all 0.15s ease;
  border: 1px solid var(--border);
  justify-content: center;
}
.confirm-actions .btn-secondary {
  background: transparent;
  color: var(--text-dim);
}
.confirm-actions .btn-secondary:hover { background: var(--bg-elev-2); color: var(--text); }
.confirm-actions .btn-refresh {
  background: var(--accent);
  color: white;
  border-color: var(--accent);
}
.confirm-actions .btn-refresh:hover { background: var(--accent-hover); border-color: var(--accent-hover); }
.confirm-actions .btn-refresh.btn-danger {
  background: var(--red);
  border-color: var(--red);
}
.confirm-actions .btn-refresh.btn-danger:hover {
  background: #DC2626;
  border-color: #DC2626;
}

.toast {
  position: fixed;
  bottom: 24px;
  right: 24px;
  padding: 12px 20px;
  background: var(--red);
  color: white;
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  transition: opacity 0.2s ease, transform 0.2s ease;
  z-index: 1000;
  max-width: 400px;
}

.toast.hidden { opacity: 0; pointer-events: none; transform: translateY(8px); }

@media (max-width: 1200px) {
  .charts { grid-template-columns: 1fr 1fr; }
  .chart-wide { grid-column: 1 / -1; }
}

@media (max-width: 900px) {
  .charts { grid-template-columns: 1fr; }
  .chart-wide { grid-column: 1; }
  .topbar { padding: 16px 20px; flex-direction: column; gap: 12px; align-items: flex-start; }
  main { padding: 20px; }
  .form-row { flex-direction: column; gap: 0; }
}

/* ─── Workspace section ──────────────────────────────────────────────── */
.ws-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}
@media (max-width: 1000px) {
  .ws-grid { grid-template-columns: 1fr; }
}
/* Quando ws-grid vive dentro la tab Workspace dell'Account, lo
   forziamo a una sola colonna così le card hanno la stessa larghezza
   di quelle di Profilo e Sicurezza (uniformità tab). */
.account-tab-panel .ws-grid { grid-template-columns: 1fr; }

/* Fotovoltaico: layout 2-col per le tabelle.
   - Colonna sx: Contratti + GSE impilati (.pv-col-stack)
   - Colonna dx: Bollette mensili (più larga, 7 colonne)
   Sotto 1200px collassa tutto su singola colonna. */
.pv-row-two {
  display: grid;
  grid-template-columns: 1fr 1.6fr;
  gap: 18px;
  margin-bottom: 18px;
  align-items: start;
}
.pv-row-two > .table-box,
.pv-row-two .pv-col-stack > .table-box { margin-bottom: 0; }
.pv-col-stack { display: flex; flex-direction: column; gap: 18px; min-width: 0; }
@media (max-width: 1200px) { .pv-row-two { grid-template-columns: 1fr; } }

.card-badge {
  background: var(--accent-soft);
  color: var(--accent);
  padding: 2px 10px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 600;
}

.ws-members-list, .ws-invites-list { display: flex; flex-direction: column; gap: 10px; }

.ws-member-row, .ws-invite-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 12px;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 10px;
}
.ws-member-info { display: flex; align-items: center; gap: 12px; }
.ws-member-avatar {
  width: 36px; height: 36px;
  background: var(--accent-soft); color: var(--accent);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-weight: 600; font-size: 13px;
}
.ws-member-name { font-weight: 500; font-size: 14px; }
.ws-member-email { font-size: 12px; color: var(--text-dim); }
.ws-self-tag { background: var(--accent-soft); color: var(--accent); font-size: 10px; padding: 1px 6px; border-radius: 4px; margin-left: 4px; }
.ws-member-actions { display: flex; align-items: center; gap: 8px; }
.ws-role-badge {
  font-size: 11px; font-weight: 600;
  padding: 3px 8px; border-radius: 6px;
  text-transform: uppercase; letter-spacing: 0.04em;
}
.ws-role-owner  { background: rgba(99,102,241,0.14); color: var(--accent); }
.ws-role-member { background: rgba(148,163,184,0.14); color: #94A3B8; }
.ws-role-viewer { background: rgba(148,163,184,0.10); color: #94A3B8; }

.ws-invite-form { display: flex; gap: 8px; margin-bottom: 14px; }
.ws-invite-form input[type=email] {
  flex: 1; padding: 9px 12px; background: var(--bg);
  border: 1px solid var(--border); border-radius: 9px;
  color: var(--text); font-size: 13px; font-family: inherit;
}
.ws-invite-form select {
  padding: 9px 12px; background: var(--bg); border: 1px solid var(--border);
  border-radius: 9px; color: var(--text); font-size: 13px; font-family: inherit;
}
.ws-invite-info { flex: 1; min-width: 0; }
.ws-invite-email { font-weight: 500; font-size: 14px; }
.ws-invite-meta { font-size: 11px; color: var(--text-dim); }
.ws-invite-actions { display: flex; gap: 6px; }

.btn-small { padding: 6px 12px !important; font-size: 12px !important; }
.btn-danger-ghost {
  background: transparent !important;
  color: var(--red) !important;
  border: 1px solid transparent !important;
}
.btn-danger-ghost:hover { background: rgba(239,68,68,0.10) !important; }

.ws-rename-input {
  width: 100%; padding: 11px 13px; margin: 16px 0;
  background: var(--bg); border: 1px solid var(--border);
  border-radius: 10px; color: var(--text); font-size: 14px; font-family: inherit;
  box-sizing: border-box;
}

/* ─── Workspace switcher in topbar ──────────────────────────────────── */
.workspace-switcher { position: relative; }
.workspace-switcher.hidden,
.workspace-switcher-menu.hidden { display: none; }
.workspace-switcher-button {
  display: flex; align-items: center; gap: 6px;
  padding: 6px 10px;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 8px;
  color: var(--text); font-size: 13px; font-weight: 500;
  cursor: pointer; font-family: inherit;
}
.workspace-switcher-button:hover { background: var(--bg-elev); }
.workspace-switcher-name { white-space: nowrap; }
.workspace-switcher-menu {
  position: absolute; top: 100%; right: 0; margin-top: 6px;
  background: var(--bg-elev);
  border: 1px solid var(--border);
  border-radius: 10px;
  box-shadow: var(--shadow);
  min-width: 220px;
  z-index: 100;
  padding: 6px;
}
.workspace-switcher-item {
  display: flex; align-items: center; justify-content: space-between;
  width: 100%; padding: 8px 10px;
  background: transparent; border: none; border-radius: 6px;
  color: var(--text); font-size: 13px; cursor: pointer; font-family: inherit;
  text-align: left;
}
.workspace-switcher-item:hover { background: var(--bg); }
.workspace-switcher-item.active { background: var(--accent-soft); color: var(--accent); }
.workspace-switcher-item .ws-role {
  font-size: 11px; opacity: 0.7; text-transform: uppercase; letter-spacing: 0.04em;
}

/* card-header/body usati nella sezione workspace */
.ws-grid .card { padding: 18px; display: flex; flex-direction: column; gap: 12px; }
.ws-grid .card-header {
  display: flex; align-items: center; justify-content: space-between; gap: 8px;
}
.ws-grid .card-header h2 { margin: 0; font-size: 14px; font-weight: 600; color: var(--text); text-transform: uppercase; letter-spacing: 0.05em; }
.ws-grid .card-body { display: flex; flex-direction: column; }

.section-subtitle { color: var(--text-dim); font-size: 13px; margin: 4px 0 0; }
.empty-state { color: var(--text-dim); font-size: 13px; padding: 14px; text-align: center; }

/* ─── Inviti in attesa (nella sezione Workspace) ────────────────────── */
.ws-pending-invites {
  background: linear-gradient(180deg, rgba(99,102,241,0.10), rgba(99,102,241,0.04));
  border: 1px solid var(--accent);
  border-radius: 12px;
  padding: 16px 18px;
  margin-bottom: 20px;
}
.ws-pending-invites.hidden { display: none; }
.ws-pending-header {
  display: flex; align-items: center; gap: 8px;
  color: var(--accent);
  font-size: 13px; font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.04em;
  margin-bottom: 12px;
}
.ws-pending-row {
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  background: var(--bg-elev);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 12px 14px;
  margin-top: 8px;
}
.ws-pending-info { flex: 1; min-width: 0; }
.ws-pending-ws { font-size: 15px; font-weight: 600; color: var(--text); }
.ws-pending-meta { font-size: 12px; color: var(--text-dim); margin-top: 2px; }

/* ─── Zona pericolo (Workspace section) ─────────────────────────────── */
.ws-danger-zone {
  margin-top: 28px;
  border: 1px solid rgba(239,68,68,0.25);
  border-radius: 12px;
  padding: 18px;
  background: rgba(239,68,68,0.03);
}
.ws-danger-zone h3 {
  margin: 0 0 14px;
  font-size: 12px; font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.06em;
  color: var(--red);
}
.ws-danger-row {
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
  padding: 12px 0;
}
.ws-danger-row + .ws-danger-row { border-top: 1px solid rgba(239,68,68,0.15); }
.ws-danger-title { font-size: 14px; font-weight: 500; color: var(--text); }
.ws-danger-desc { font-size: 12px; color: var(--text-dim); margin-top: 2px; max-width: 540px; }
.btn-danger-text {
  border-color: var(--red) !important;
  color: var(--red) !important;
}
.btn-danger-text:hover { background: rgba(239,68,68,0.10) !important; }

/* ===== Sezione Account ===== */
.account-tabs {
  display: flex;
  gap: 4px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 24px;
}
.account-tab {
  background: transparent;
  border: none;
  color: var(--text-dim);
  font-size: 14px;
  font-weight: 500;
  font-family: inherit;
  padding: 10px 16px;
  cursor: pointer;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  transition: color 0.15s, border-color 0.15s;
}
.account-tab:hover { color: var(--text); }
.account-tab.active {
  color: var(--accent);
  border-bottom-color: var(--accent);
}
.account-tab-panel { display: block !important; width: 100% !important; min-width: 100% !important; }
.account-tab-panel.hidden { display: none !important; }
/* Forza tutti i figli diretti dei tab Account alla stessa larghezza
   piena del panel così Profilo / Sicurezza / Workspace condividono
   esattamente lo stesso "cap" visivo. */
.account-tab-panel > *,
.account-tab-panel > #workspacePanelHost > * { width: 100%; box-sizing: border-box; }

.account-form .form-row { flex-direction: column; gap: 0; margin-bottom: 14px; }
.account-form .form-row label {
  display: block;
  margin-bottom: 6px;
  font-size: 12px;
  color: var(--text-dim);
}
.account-form input {
  display: block;
  width: 100%;
  padding: 9px 12px;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 8px;
  color: var(--text);
  font-size: 13px;
  font-family: inherit;
}
.account-form input:focus {
  outline: none;
  border-color: var(--accent);
}
.account-form .form-hint {
  display: block;
  margin-top: 4px;
  font-size: 11px;
  color: var(--text-dim);
}

#deleteAccountModal .ws-rename-input {
  margin: 14px 0;
}

/* ===== Modale Statistiche Fotovoltaico ===== */
.pv-stats-modal .modal-content {
  max-width: 1200px;
  max-height: 90vh;
}
.pv-stats-body {
  padding: 18px 22px;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.pv-stats-card {
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 16px 18px;
}
.pv-stats-card.hidden { display: none; }
.pv-stats-body > .empty-state.hidden { display: none; }
.pv-stats-card h3 {
  margin: 0 0 4px;
  font-size: 14px;
  font-weight: 600;
  color: var(--text);
}
.pv-stats-card .hint {
  margin: 0 0 12px;
  font-size: 12px;
  color: var(--text-dim);
  line-height: 1.5;
}
.pv-stats-card-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
  margin-bottom: 10px;
}
.pv-stats-card-head h3 { margin-bottom: 4px; }
.pv-stats-card-head .hint { margin-bottom: 0; }
.pv-stats-canvas-wrap {
  position: relative;
  height: 260px;
}
.pv-stats-canvas-wrap canvas { width: 100% !important; height: 100% !important; }

.pv-heatmap {
  overflow-x: auto;
}
.pv-heatmap-legend {
  margin-top: 10px;
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 11px;
  color: var(--text-dim);
}
.pv-heatmap-grad {
  flex: 0 0 120px;
  height: 8px;
  border-radius: 4px;
  background: linear-gradient(
    to right,
    rgba(255,255,255,0.04),
    rgba(80, 200, 120, 1)
  );
}

/* =========================================================================
 * Guardrail anti-overflow orizzontale (sempre attivo)
 * =========================================================================
 * Su mobile capita che un singolo elemento (canvas Chart.js, tabella senza
 * wrap, container che non rispetta min-width: 0 in un grid) faccia espandere
 * tutto il viewport rovinando il layout. Questi guardrail evitano lo
 * scroll-x della pagina, lasciando lo scroll dove deve stare (table-wrapper).
 * ========================================================================= */
html, body { overflow-x: hidden; }
.section-content { max-width: 100vw; overflow-x: hidden; }
.section-content canvas { max-width: 100% !important; }
/* Grid item devono potersi restringere sotto il loro contenuto intrinseco */
.cards, .charts, .row-top, .row-mid, .detail-cards, .periods-grid { min-width: 0; }
.cards > *, .charts > *, .row-top > *, .row-mid > *,
.detail-cards > *, .periods-grid > * { min-width: 0; }

/* =========================================================================
 * Ottimizzazioni mobile (PWA / iPhone)
 * =========================================================================
 * Sotto 700px (la stessa soglia della bottom tab bar):
 *  - tabelle: scroll touch + font/padding ridotti + edge-to-edge
 *  - form: input più alti (44px min touch target) + font 16px per non
 *    triggherare il zoom automatico iOS sui tap
 *  - bottoni: touch target più generosi
 *  - card grid: collassano a 1 colonna se ancora a 2
 *
 * Sotto 600px:
 *  - modal: fullscreen (niente cornici e padding sprecati)
 *  - detail-cards: 1 colonna
 * ========================================================================= */
@media (max-width: 700px) {
  /* Tabelle: edge-to-edge + scroll touch fluido */
  .section-content .table-wrapper,
  .section-content .table-wrap {
    -webkit-overflow-scrolling: touch;
    margin-left: -14px;
    margin-right: -14px;
    padding: 0 14px;
  }
  .section-content table { font-size: 11.5px; }
  .section-content th,
  .section-content td { padding-left: 8px; padding-right: 8px; }

  /* Card grid: forza a 1-2 col per evitare card schiacciate */
  .cards { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .detail-cards { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .periods-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }

  /* Section headers più compatti */
  .section-content h2 { font-size: 18px; }
  .section-content h3 { font-size: 15px; }

  /* Form: input ≥44px (Apple HIG) + font 16px (no iOS zoom) */
  .asset-form input, .asset-form select, .asset-form textarea,
  .targets-form input,
  .login-form input,
  input[type="text"], input[type="email"], input[type="password"],
  input[type="number"], input[type="date"], input[type="search"],
  input[type="tel"], input[type="url"],
  select, textarea {
    font-size: 16px;
    min-height: 44px;
    padding: 10px 12px;
  }
  textarea { min-height: 80px; }

  /* Bottoni: touch target + non si comprimono troppo */
  .btn-refresh, .btn-secondary, .btn-icon-only {
    min-height: 40px;
    padding-left: 14px;
    padding-right: 14px;
  }
  .btn-icon-action { width: 36px; height: 36px; }

  /* Pills/scroll orizzontali: enable native momentum */
  .pills, .pills-scroll, .year-pills, .tabs {
    -webkit-overflow-scrolling: touch;
  }
}

@media (max-width: 600px) {
  /* Modal: fullscreen */
  .modal {
    padding: 0;
    align-items: stretch;
    justify-content: stretch;
  }
  .modal-content,
  .modal-content.modal-narrow,
  .modal-content.modal-wide {
    max-width: none;
    max-height: none;
    width: 100%;
    height: 100%;
    border-radius: 0;
    border: none;
    /* lascia spazio sicuro top/bottom su iPhone con notch / home indicator */
    padding-top: env(safe-area-inset-top);
    padding-bottom: env(safe-area-inset-bottom);
  }
  .modal-head { padding-left: 16px; padding-right: 16px; }
  .modal-body,
  .asset-form { padding-left: 16px; padding-right: 16px; }
  .modal-actions {
    padding: 12px 16px;
    flex-wrap: wrap;
    /* Sticky in fondo, per non scomparire sotto la tastiera quando salvi */
    position: sticky;
    bottom: 0;
    background: var(--bg-elev);
  }

  /* Confirm dialog fullscreen */
  .confirm-overlay { padding: 0; align-items: stretch; }
  .confirm-box {
    width: 100%;
    max-width: none;
    border-radius: 0;
    border: none;
    padding-top: env(safe-area-inset-top);
    padding-bottom: env(safe-area-inset-bottom);
  }

  /* Card grid: collassa a 1 col */
  .cards { grid-template-columns: 1fr; }
  .detail-cards { grid-template-columns: 1fr; }
}
