/* ============================================================
   DASHBOARD PSICOLOGIA — style.css
   Design system: Apple-inspired, clean, professional
   ============================================================ */

/* ─── VARIABLES ─── */
:root {
  --bg:            #f5f5f7;
  --card:          #ffffff;
  --border:        #e5e5ea;
  --border-light:  #f0f0f5;
  --text:          #1d1d1f;
  --text-2:        #6e6e73;
  --text-3:        #aeaeb2;
  --primary:       #007AFF;
  --primary-soft:  #e8f2ff;
  --success:       #34C759;
  --success-soft:  #e5f8eb;
  --warning:       #FF9500;
  --warning-soft:  #fff3e0;
  --danger:        #FF3B30;
  --danger-soft:   #ffe8e6;
  --purple:        #5856D6;
  --purple-soft:   #eeeeff;
  --teal:          #5AC8FA;
  --teal-soft:     #e6f7ff;
  --gray:          #8E8E93;
  --gray-soft:     #f2f2f7;
  --yellow:        #FFD60A;
  --yellow-soft:   #fffbe6;

  /* Channel */
  --c-sp:   #007AFF;
  --c-ccnp: #5856D6;
  --c-ub:   #34C759;
  --c-ubg:  #5AC8FA;
  --c-asl:  #FF9500;

  /* Spacing */
  --s1: 4px; --s2: 8px; --s3: 12px; --s4: 16px;
  --s5: 20px; --s6: 24px; --s7: 28px; --s8: 32px;

  /* Radius */
  --r1: 6px; --r2: 10px; --r3: 14px; --r4: 20px;

  /* Shadows */
  --shadow-xs: 0 1px 2px rgba(0,0,0,.06);
  --shadow-sm: 0 1px 4px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.04);
  --shadow-md: 0 4px 16px rgba(0,0,0,.1), 0 1px 4px rgba(0,0,0,.05);
  --shadow-lg: 0 8px 32px rgba(0,0,0,.14), 0 2px 8px rgba(0,0,0,.06);
  --shadow-panel: -2px 0 32px rgba(0,0,0,.12);

  /* Layout */
  --header-h: 66px;
  --panel-w: 430px;
  --panel-wide-w: 580px;
}

/* ─── RESET & BASE ─── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: 14px; -webkit-font-smoothing: antialiased; }
body {
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif;
  background: var(--bg);
  color: var(--text);
  line-height: 1.5;
  min-height: 100vh;
}
button { cursor: pointer; border: none; background: none; font: inherit; }
input, select, textarea { font: inherit; }
a { color: var(--primary); text-decoration: none; }

/* ─── SCROLLBAR ─── */
::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--border); border-radius: 3px; }

/* ─── LAYOUT ─── */
#app { min-height: 100vh; display: flex; flex-direction: column; }

.app-bar {
  position: fixed; top: 0; left: 0; right: 0; z-index: 100;
  height: var(--header-h);
  background: rgba(255,255,255,.85);
  backdrop-filter: blur(20px) saturate(180%);
  -webkit-backdrop-filter: blur(20px) saturate(180%);
  border-bottom: 1px solid var(--border);
}
.app-bar-inner {
  max-width: 1440px; margin: 0 auto; padding: 0 var(--s6);
  height: 100%; display: flex; align-items: center; gap: var(--s6);
}
.app-logo {
  display: flex; align-items: center; gap: var(--s2);
  flex-shrink: 0;
}
.app-logo-img {
  height: 56px; width: auto; object-fit: contain; display: block;
}
.app-logo-text {
  font-size: 16px; font-weight: 600; color: var(--text); letter-spacing: -.3px;
}

/* Tab nav */
.tab-nav {
  display: flex; align-items: center; gap: var(--s1);
  background: var(--gray-soft);
  border-radius: var(--r2);
  padding: 3px;
}
.tab-btn {
  display: flex; align-items: center; gap: var(--s2);
  padding: 6px var(--s4);
  border-radius: 8px;
  font-size: 13px; font-weight: 500;
  color: var(--text-2);
  transition: all .18s ease;
  white-space: nowrap;
}
.tab-btn svg { opacity: .7; flex-shrink: 0; }
.tab-btn:hover { background: rgba(255,255,255,.7); color: var(--text); }
.tab-btn.active {
  background: var(--card);
  color: var(--primary);
  box-shadow: var(--shadow-sm);
}
.tab-btn.active svg { opacity: 1; }
.tab-btn--guide { margin-left: auto; }

.app-main {
  margin-top: var(--header-h);
  flex: 1;
  max-width: 1440px; width: 100%;
  margin-left: auto; margin-right: auto;
  padding: var(--s6);
}

/* Tab panes */
.tab-pane { display: none; }
.tab-pane.active { display: block; }

/* ─── BUTTONS ─── */
.btn-primary {
  display: inline-flex; align-items: center; gap: var(--s2);
  padding: 8px var(--s4);
  background: var(--primary); color: #fff;
  border-radius: var(--r2); font-size: 13px; font-weight: 600;
  transition: all .15s ease;
  cursor: pointer; border: none;
}
.btn-primary:hover { background: #0066DD; transform: translateY(-1px); box-shadow: 0 2px 8px rgba(0,122,255,.3); }
.btn-primary:active { transform: translateY(0); }

.btn-secondary {
  display: inline-flex; align-items: center; gap: var(--s2);
  padding: 7px var(--s4);
  background: var(--card); color: var(--primary);
  border: 1px solid var(--border); border-radius: var(--r2);
  font-size: 13px; font-weight: 500;
  transition: all .15s ease; cursor: pointer;
}
.btn-secondary:hover { background: var(--primary-soft); border-color: var(--primary); }

.btn-ghost {
  display: inline-flex; align-items: center; gap: var(--s2);
  padding: 6px var(--s3);
  color: var(--text-2); border-radius: var(--r1);
  font-size: 12px; font-weight: 500;
  transition: all .15s; cursor: pointer;
}
.btn-ghost:hover { background: var(--gray-soft); color: var(--text); }

.btn-danger {
  display: inline-flex; align-items: center; gap: var(--s2);
  padding: 7px var(--s4);
  background: var(--danger-soft); color: var(--danger);
  border: 1px solid rgba(255,59,48,.15); border-radius: var(--r2);
  font-size: 13px; font-weight: 500; cursor: pointer;
  transition: all .15s;
}
.btn-danger:hover { background: var(--danger); color: #fff; }

.btn-icon {
  width: 32px; height: 32px;
  display: inline-flex; align-items: center; justify-content: center;
  border-radius: var(--r1); color: var(--text-2);
  transition: all .15s; cursor: pointer; flex-shrink: 0;
}
.btn-icon:hover { background: var(--gray-soft); color: var(--text); }
.btn-icon.danger:hover { background: var(--danger-soft); color: var(--danger); }

/* ─── FORMS ─── */
.form-group { display: flex; flex-direction: column; gap: var(--s1); }
.form-label {
  font-size: 12px; font-weight: 600; color: var(--text-2);
  text-transform: uppercase; letter-spacing: .4px;
}
.form-label .req { color: var(--danger); }
.form-input, .form-select, .form-textarea {
  width: 100%;
  padding: 9px var(--s3);
  border: 1.5px solid var(--border);
  border-radius: var(--r2);
  font-size: 13px; color: var(--text);
  background: var(--card);
  transition: border-color .15s, box-shadow .15s;
  outline: none;
}
.form-input:focus, .form-select:focus, .form-textarea:focus {
  border-color: var(--primary);
  box-shadow: 0 0 0 3px rgba(0,122,255,.12);
}
.form-input::placeholder { color: var(--text-3); }
.form-textarea { resize: vertical; min-height: 64px; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--s3); }
.form-row-3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: var(--s3); }
.form-section {
  background: var(--gray-soft);
  border-radius: var(--r2); padding: var(--s3);
  display: flex; flex-direction: column; gap: var(--s3);
}
.form-section-title {
  font-size: 11px; font-weight: 700; color: var(--text-2);
  text-transform: uppercase; letter-spacing: .5px;
}

/* ─── BADGES ─── */
.badge {
  display: inline-flex; align-items: center;
  padding: 2px 8px;
  border-radius: 20px;
  font-size: 11px; font-weight: 700;
  letter-spacing: .2px; white-space: nowrap;
}
.badge-sp   { background: rgba(0,122,255,.12);  color: var(--c-sp); }
.badge-ccnp { background: rgba(88,86,214,.12); color: var(--c-ccnp); }
.badge-ub   { background: rgba(52,199,89,.12);  color: var(--c-ub); }
.badge-ubg  { background: rgba(90,200,250,.15); color: #0099cc; }
.badge-asl  { background: rgba(255,149,0,.12);  color: var(--c-asl); }
.badge-attivo { background: var(--success-soft); color: var(--success); }
.badge-valutazione { background: var(--yellow-soft); color: #cc9900; }
.badge-chiuso { background: var(--gray-soft); color: var(--gray); }

/* ─── CARD ─── */
.card {
  background: var(--card);
  border-radius: var(--r3);
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--border-light);
}
.card-pad { padding: var(--s6); }

/* ─── CALENDAR ─── */
.cal-toolbar {
  display: flex; align-items: center; gap: var(--s4);
  margin-bottom: var(--s5);
}
.cal-month-title {
  font-size: 22px; font-weight: 700; color: var(--text);
  letter-spacing: -.5px; min-width: 220px; text-align: center;
  text-transform: capitalize;
}
.nav-arrow {
  width: 36px; height: 36px;
  display: flex; align-items: center; justify-content: center;
  background: var(--card); border: 1px solid var(--border);
  border-radius: 50%; font-size: 20px; color: var(--text-2);
  box-shadow: var(--shadow-xs);
  transition: all .15s; cursor: pointer;
}
.nav-arrow:hover { background: var(--primary); color: #fff; border-color: var(--primary); }

.cal-wrap { overflow-x: auto; }

.cal-grid {
  background: var(--card);
  border-radius: var(--r3);
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--border-light);
  overflow: hidden;
  min-width: 900px;
}

/* Calendar rows */
.cal-row {
  display: grid;
  grid-template-columns: repeat(7, 1fr) 110px;
}
.cal-row + .cal-row { border-top: 1px solid var(--border-light); }

.cal-cell {
  min-height: 90px;
  padding: var(--s2) var(--s3);
  border-right: 1px solid var(--border-light);
  cursor: pointer;
  transition: background .15s;
  position: relative;
}
.cal-cell:last-child { border-right: none; cursor: default; }
.cal-cell:hover:not(.cal-cell--head):not(.cal-cell--pad):not(.cal-cell--week-total) {
  background: var(--primary-soft);
}

.cal-cell--head {
  min-height: unset; padding: 10px var(--s3);
  font-size: 11px; font-weight: 700; color: var(--text-2);
  text-transform: uppercase; letter-spacing: .5px;
  background: var(--gray-soft);
  cursor: default;
  display: flex; align-items: center;
}
.cal-cell--head:last-child { justify-content: center; }
.cal-cell--pad {
  background: #fafafa; cursor: default;
  min-height: 90px;
}
.cal-cell--week-total {
  cursor: default;
  display: flex; align-items: center; justify-content: center;
  background: #fafafa;
}
.cal-cell--today { background: var(--primary-soft); }
.cal-cell--today .cell-num { color: var(--primary); font-weight: 700; }
.cal-cell--active .cell-num { font-weight: 600; }

.cell-num {
  font-size: 14px; font-weight: 500; color: var(--text-2);
  margin-bottom: var(--s1);
}
.cell-body {
  display: flex; flex: 1; gap: 4px; min-height: 0;
}
.cell-left { flex: 1; display: flex; align-items: center; justify-content: center; }
.cell-right { flex: 1; display: flex; flex-direction: column; align-items: flex-end; gap: 2px; }
.cell-counts {
  display: flex; flex-wrap: wrap; gap: 2px;
  margin-bottom: var(--s1);
}
.cc {
  font-size: 10px; font-weight: 700;
  padding: 1px 5px; border-radius: 10px;
  line-height: 1.4;
}
.cc--sp   { background: rgba(0,122,255,.12); color: var(--c-sp); }
.cc--ccnp { background: rgba(88,86,214,.12); color: var(--c-ccnp); }
.cc--ub   { background: rgba(52,199,89,.12); color: var(--c-ub); }
.cc--ubg  { background: rgba(90,200,250,.15); color: #0099cc; }
.cc--asl  { background: rgba(255,149,0,.12); color: var(--c-asl); }

.cell-rev {
  font-size: 15px; font-weight: 700; color: var(--text);
  letter-spacing: -.3px;
}

.wt {
  font-size: 13px; font-weight: 700; color: var(--text-2);
  letter-spacing: -.2px;
}

.cal-month-summary {
  margin-top: var(--s5);
  background: var(--card);
  border: 1px solid var(--border-light);
  border-radius: var(--r3);
  box-shadow: var(--shadow-sm);
  padding: var(--s5) var(--s6);
  display: grid;
  grid-template-columns: minmax(280px, 1.1fr) 2fr;
  gap: var(--s6);
  align-items: center;
  position: relative;
  overflow: hidden;
}
/* sottile accent gradient sul bordo sinistro */
.cal-month-summary::before {
  content: ''; position: absolute;
  left: 0; top: 0; bottom: 0; width: 4px;
  background: linear-gradient(180deg, var(--c-sp) 0%, var(--c-ub) 60%, var(--c-asl) 100%);
}
.month-summary-left {
  display: flex; flex-direction: column;
  align-items: center;            /* centro orizzontale */
  justify-content: center;
  border-right: 1px solid var(--border-light);
  padding: var(--s2) var(--s5);
  text-align: center;
}
.month-summary-label {
  display: flex; align-items: center; gap: 6px;
  font-size: 11px; font-weight: 700; color: var(--text-2);
  text-transform: uppercase; letter-spacing: .5px;
  justify-content: center;
}
.month-summary-total {
  display: flex; justify-content: center; align-items: center;
  width: 100%;
  margin-top: var(--s2);
  line-height: 1;
}
.month-total-svg {
  display: block;
  width: 100%;
  max-width: 290px;
  height: auto;
}
.month-summary-breakdown {
  display: flex; flex-direction: column; gap: 6px;
}
.month-summary-empty {
  color: var(--text-3); font-size: 13px; font-style: italic;
}
.summary-item {
  display: grid;
  grid-template-columns: 56px 1fr auto;
  gap: var(--s3);
  align-items: center;
  padding: 7px var(--s3);
  border-radius: var(--r1);
  background: var(--c-soft, var(--gray-soft));
  transition: background .15s;
}
.summary-item-badge {
  font-size: 10.5px; font-weight: 800;
  letter-spacing: .4px; text-align: center;
  padding: 3px 8px; border-radius: 999px;
  background: var(--c-channel);
  color: #fff;
  font-variant-numeric: tabular-nums;
}
.summary-item-meaning {
  font-size: 13px; font-weight: 600;
  color: var(--c-channel);
}
.summary-item-amount {
  font-size: 15px; font-weight: 800;
  color: var(--c-channel);
  font-variant-numeric: tabular-nums;
  text-align: right;
  letter-spacing: -.3px;
}

/* Channel-specific colors (var --c-channel + soft bg) */
.summary-item--SP   { --c-channel: var(--c-sp);   --c-soft: var(--primary-soft); }
.summary-item--CCNP { --c-channel: var(--c-ccnp); --c-soft: var(--purple-soft); }
.summary-item--UB   { --c-channel: var(--c-ub);   --c-soft: var(--success-soft); }
.summary-item--ASL  { --c-channel: var(--c-asl);  --c-soft: var(--warning-soft); }

@media (max-width: 760px) {
  .cal-month-summary {
    grid-template-columns: 1fr; gap: var(--s4);
  }
  .month-summary-left {
    border-right: none;
    border-bottom: 1px solid var(--border-light);
    padding-right: 0; padding-bottom: var(--s4);
    align-items: center; text-align: center;
  }
  .summary-item { grid-template-columns: 50px 1fr auto; }
}

/* ─── SIDE PANEL ─── */
.overlay {
  position: fixed; inset: 0; z-index: 200;
  background: rgba(0,0,0,.2);
  backdrop-filter: blur(2px);
  opacity: 0; pointer-events: none;
  transition: opacity .25s ease;
}
.overlay.active { opacity: 1; pointer-events: auto; }

.side-panel {
  position: fixed; top: 0; right: 0; bottom: 0; z-index: 300;
  width: var(--panel-w);
  background: var(--card);
  box-shadow: var(--shadow-panel);
  display: flex; flex-direction: column;
  transform: translateX(100%);
  transition: transform .28s cubic-bezier(.4,0,.2,1);
}
.side-panel--wide { width: var(--panel-wide-w); }
.side-panel[data-open="true"] { transform: translateX(0); }

.sp-header {
  display: flex; align-items: flex-start; justify-content: space-between;
  padding: var(--s5) var(--s5) var(--s4);
  border-bottom: 1px solid var(--border-light);
  flex-shrink: 0;
}
.sp-title { font-size: 17px; font-weight: 700; color: var(--text); letter-spacing: -.3px; }
.sp-subtitle { font-size: 12px; color: var(--text-2); margin-top: 2px; }
.sp-close {
  width: 28px; height: 28px;
  display: flex; align-items: center; justify-content: center;
  background: var(--gray-soft); border-radius: 50%;
  color: var(--text-2); flex-shrink: 0;
  transition: all .15s; cursor: pointer;
}
.sp-close:hover { background: var(--border); color: var(--text); }

.sp-body {
  flex: 1; overflow-y: auto;
  padding: var(--s4) var(--s5) var(--s6);
  display: flex; flex-direction: column; gap: var(--s4);
}

/* ─── DAY PANEL ─── */
.dp-section-title {
  font-size: 11px; font-weight: 700; color: var(--text-2);
  text-transform: uppercase; letter-spacing: .5px;
  margin-bottom: var(--s2);
}

.session-item {
  display: flex; align-items: center; gap: var(--s2);
  padding: var(--s3);
  background: var(--gray-soft);
  border-radius: var(--r2);
  transition: background .12s;
}
.session-item:hover { background: var(--border-light); }
.session-item-name { flex: 1; font-size: 13px; font-weight: 600; }
.session-item-type { font-size: 11px; color: var(--text-2); }
.pagato-toggle {
  padding: 3px 8px;
  border-radius: 10px; font-size: 11px; font-weight: 600;
  cursor: pointer; transition: all .12s; border: none;
}
.pagato-toggle.si { background: var(--success-soft); color: var(--success); }
.pagato-toggle.no { background: var(--gray-soft); color: var(--text-2); border: 1px solid var(--border); }
.pagato-toggle.na { background: transparent; color: var(--text-3); cursor: default; font-size: 11px; }

.btn-add-session {
  display: flex; align-items: center; gap: var(--s2);
  padding: var(--s3) var(--s4);
  border: 1.5px dashed var(--border);
  border-radius: var(--r2);
  color: var(--primary); font-size: 13px; font-weight: 600;
  width: 100%; justify-content: center;
  transition: all .15s; cursor: pointer;
  background: transparent;
}
.btn-add-session:hover { border-color: var(--primary); background: var(--primary-soft); }

/* Add session form */
.add-session-form {
  background: var(--gray-soft);
  border-radius: var(--r2); padding: var(--s4);
  display: flex; flex-direction: column; gap: var(--s3);
}
.add-session-form.hidden { display: none; }

/* Autocomplete */
.autocomplete-wrap { position: relative; }
.autocomplete-dropdown {
  position: absolute; top: 100%; left: 0; right: 0; z-index: 50;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--r2);
  box-shadow: var(--shadow-md);
  max-height: 220px; overflow-y: auto;
  margin-top: 2px;
}
.autocomplete-item {
  padding: 9px var(--s3);
  cursor: pointer;
  display: flex; align-items: center; gap: var(--s2);
  transition: background .1s;
  font-size: 13px;
}
.autocomplete-item:hover { background: var(--primary-soft); }
.autocomplete-item-name { font-weight: 600; flex: 1; }
.autocomplete-item-sub { font-size: 11px; color: var(--text-2); }
.autocomplete-new {
  padding: 9px var(--s3);
  cursor: pointer;
  display: flex; align-items: center; gap: var(--s2);
  font-size: 13px; font-weight: 600; color: var(--primary);
  border-top: 1px solid var(--border-light);
}
.autocomplete-new:hover { background: var(--primary-soft); }

/* ASL stepper */
.asl-row {
  display: flex; align-items: center; justify-content: space-between;
  padding: var(--s3) var(--s4);
  background: rgba(255,149,0,.08);
  border-radius: var(--r2);
  border: 1px solid rgba(255,149,0,.2);
}
.asl-label { display: flex; align-items: center; gap: var(--s2); font-size: 13px; font-weight: 600; color: var(--c-asl); }
.stepper {
  display: flex; align-items: center; gap: var(--s2);
}
.step-btn {
  width: 28px; height: 28px;
  background: var(--card); border: 1px solid var(--border);
  border-radius: 50%; font-size: 16px; font-weight: 600;
  color: var(--text); display: flex; align-items: center; justify-content: center;
  cursor: pointer; transition: all .12s; user-select: none; line-height: 1;
}
.step-btn:hover { background: var(--primary); color: #fff; border-color: var(--primary); }
.step-display {
  width: 52px; text-align: center;
  border: 1.5px solid var(--border); border-radius: var(--r1);
  padding: 4px; font-size: 14px; font-weight: 700;
  color: var(--c-asl);
  -moz-appearance: textfield;
}
.step-display::-webkit-inner-spin-button { display: none; }

.day-total-card {
  background: var(--text);
  border-radius: var(--r2);
  padding: var(--s4);
  display: flex; align-items: center; justify-content: space-between;
}
.day-total-label { font-size: 12px; font-weight: 600; color: rgba(255,255,255,.6); text-transform: uppercase; letter-spacing: .4px; }
.day-total-value { font-size: 24px; font-weight: 700; color: #fff; letter-spacing: -.5px; }
.day-total-breakdown { display: flex; flex-wrap: wrap; gap: var(--s2); margin-top: var(--s2); }
.day-total-item { font-size: 11px; color: rgba(255,255,255,.7); }

/* New patient inline form */
.new-patient-inline {
  background: var(--primary-soft);
  border: 1.5px solid rgba(0,122,255,.2);
  border-radius: var(--r2); padding: var(--s4);
  display: flex; flex-direction: column; gap: var(--s3);
}
.new-patient-inline.hidden { display: none; }

/* ─── MODAL ─── */
.modal-overlay {
  position: fixed; inset: 0; z-index: 400;
  background: rgba(0,0,0,.25);
  backdrop-filter: blur(4px);
  display: flex; align-items: center; justify-content: center;
  padding: var(--s6);
  opacity: 0; pointer-events: none;
  transition: opacity .2s;
}
.modal-overlay.active { opacity: 1; pointer-events: auto; }
.modal-card {
  background: var(--card);
  border-radius: var(--r4);
  box-shadow: var(--shadow-lg);
  width: 100%; max-width: 560px;
  max-height: 90vh;
  display: flex; flex-direction: column;
  transform: scale(.96);
  transition: transform .2s ease;
}
.modal-overlay.active .modal-card { transform: scale(1); }
.modal-card-body {
  padding: var(--s5);
  overflow-y: auto;
  display: flex; flex-direction: column; gap: var(--s4);
}

/* ─── CRM ─── */
.crm-stats-row {
  display: grid; grid-template-columns: 1fr 1fr; gap: var(--s4);
  margin-bottom: var(--s5);
}
.stat-chart-card {
  background: var(--card);
  border-radius: var(--r3); box-shadow: var(--shadow-sm);
  border: 1px solid var(--border-light);
  padding: var(--s5);
}
.stat-chart-card h4 {
  font-size: 13px; font-weight: 700; color: var(--text);
  margin-bottom: var(--s4); letter-spacing: -.2px;
}
.chart-canvas-wrap { position: relative; height: 180px; }

.crm-toolbar {
  display: flex; align-items: center; gap: var(--s3);
  margin-bottom: var(--s4);
  flex-wrap: wrap;
}
.search-input {
  flex: 1; min-width: 200px;
  padding: 9px var(--s3) 9px 36px;
  border: 1.5px solid var(--border);
  border-radius: var(--r2); font-size: 13px; color: var(--text);
  background: var(--card) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23aeaeb2' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cline x1='21' y1='21' x2='16.65' y2='16.65'/%3E%3C/svg%3E") no-repeat 12px center;
  outline: none; transition: border-color .15s, box-shadow .15s;
}
.search-input:focus { border-color: var(--primary); box-shadow: 0 0 0 3px rgba(0,122,255,.12); }
.filter-select {
  padding: 8px var(--s3);
  border: 1.5px solid var(--border); border-radius: var(--r2);
  font-size: 13px; color: var(--text);
  background: var(--card); outline: none;
  cursor: pointer; transition: border-color .15s;
  min-width: 140px;
}
.filter-select:focus { border-color: var(--primary); }

/* Patient table */
.patient-table-wrap {
  background: var(--card);
  border-radius: var(--r3); box-shadow: var(--shadow-sm);
  border: 1px solid var(--border-light);
  overflow: hidden;
}
.patient-table {
  width: 100%; border-collapse: collapse;
}
.patient-table th {
  padding: 10px var(--s4);
  font-size: 11px; font-weight: 700; color: var(--text-2);
  text-transform: uppercase; letter-spacing: .5px;
  background: var(--gray-soft);
  border-bottom: 1px solid var(--border-light);
  text-align: left; white-space: nowrap;
  cursor: pointer; user-select: none;
}
.patient-table th:hover { color: var(--text); }
.patient-table th.sort-asc::after { content: ' ↑'; color: var(--primary); }
.patient-table th.sort-desc::after { content: ' ↓'; color: var(--primary); }
.patient-table td {
  padding: 11px var(--s4);
  border-bottom: 1px solid var(--border-light);
  font-size: 13px;
}
.patient-table tr:last-child td { border-bottom: none; }
.patient-table tr:hover td { background: var(--primary-soft); cursor: pointer; }
.pt-name { font-weight: 600; }
.pt-np { font-weight: 700; color: var(--danger); }
.empty-state {
  padding: var(--s8); text-align: center;
  color: var(--text-2);
}
.empty-state h3 { font-size: 15px; font-weight: 600; margin-bottom: var(--s2); }
.empty-state p { font-size: 13px; }

/* Patient panel */
.pp-section { margin-bottom: var(--s5); }
.pp-section-title {
  font-size: 11px; font-weight: 700; color: var(--text-2);
  text-transform: uppercase; letter-spacing: .5px;
  margin-bottom: var(--s3);
  padding-bottom: var(--s2);
  border-bottom: 1px solid var(--border-light);
}
.pp-field-row {
  display: grid; grid-template-columns: 1fr 1fr; gap: var(--s3);
  margin-bottom: var(--s3);
}
.pp-field { display: flex; flex-direction: column; gap: 2px; }
.pp-field-label { font-size: 11px; color: var(--text-2); font-weight: 500; }
.pp-field-value { font-size: 13px; font-weight: 600; color: var(--text); }

.pp-stats-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--s3);
  margin-bottom: var(--s4);
}
.pp-stat-card {
  background: var(--gray-soft); border-radius: var(--r2);
  padding: var(--s3); text-align: center;
}
.pp-stat-value { font-size: 22px; font-weight: 700; color: var(--text); }
.pp-stat-label { font-size: 11px; color: var(--text-2); font-weight: 500; margin-top: 2px; }

.sessions-mini-table { width: 100%; border-collapse: collapse; }
.sessions-mini-table th {
  font-size: 11px; font-weight: 600; color: var(--text-2); text-align: left;
  padding: 4px var(--s2); border-bottom: 1px solid var(--border-light);
}
.sessions-mini-table td {
  font-size: 12px; padding: 6px var(--s2);
  border-bottom: 1px solid var(--border-light);
}
.sessions-mini-table tr:last-child td { border-bottom: none; }

/* ─── CASH FLOW ─── */
.cf-upload-area {
  background: var(--card); border-radius: var(--r3);
  box-shadow: var(--shadow-sm); border: 1px solid var(--border-light);
  padding: var(--s6); margin-bottom: var(--s5);
}
.drop-zone {
  border: 2px dashed var(--border);
  border-radius: var(--r2); padding: var(--s8);
  text-align: center;
  transition: all .2s; cursor: pointer;
}
.drop-zone:hover, .drop-zone.dragover {
  border-color: var(--primary);
  background: var(--primary-soft);
}
.drop-zone-icon {
  width: 48px; height: 48px;
  background: var(--primary-soft);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto var(--s4);
  color: var(--primary);
}
.drop-title { font-size: 15px; font-weight: 600; color: var(--text); margin-bottom: var(--s2); }
.drop-sub { font-size: 13px; color: var(--text-2); margin-bottom: var(--s4); }
.bank-loaded-info {
  display: flex; align-items: center; gap: var(--s3);
  padding: var(--s3) var(--s4);
  background: var(--success-soft); border-radius: var(--r2);
  font-size: 13px; color: var(--success); font-weight: 600;
}

.cf-charts-row {
  display: grid; grid-template-columns: 1.5fr 1fr; gap: var(--s4);
  margin-bottom: var(--s5);
}
.cf-chart-card {
  background: var(--card); border-radius: var(--r3);
  box-shadow: var(--shadow-sm); border: 1px solid var(--border-light);
  padding: var(--s5);
}
.cf-chart-card h4 {
  font-size: 13px; font-weight: 700; color: var(--text);
}
.cf-chart-head {
  display: flex; flex-direction: column; gap: 2px;
  margin-bottom: var(--s4);
}
.cf-chart-period {
  font-size: 10.5px; color: var(--text-3); font-weight: 500;
  letter-spacing: .1px;
  font-variant-numeric: tabular-nums;
}
.cf-chart-period b {
  color: var(--text); font-weight: 700;
}
.cf-chart-wrap { position: relative; height: 220px; }

.reconciliation-card {
  background: var(--card); border-radius: var(--r3);
  box-shadow: var(--shadow-sm); border: 1px solid var(--border-light);
  overflow: hidden;
}
.reconciliation-card h4 {
  font-size: 14px; font-weight: 700; color: var(--text);
  padding: var(--s4) var(--s5);
  border-bottom: 1px solid var(--border-light);
}
.recon-table { width: 100%; border-collapse: collapse; }
.recon-table th {
  font-size: 11px; font-weight: 700; color: var(--text-2);
  text-transform: uppercase; letter-spacing: .4px;
  padding: 10px var(--s5);
  background: var(--gray-soft);
  border-bottom: 1px solid var(--border-light);
  text-align: right;
}
.recon-table th:first-child { text-align: left; }
.recon-table td {
  padding: 12px var(--s5);
  font-size: 13px;
  border-bottom: 1px solid var(--border-light);
  text-align: right;
}
.recon-table td:first-child { text-align: left; font-weight: 600; }
.recon-table tr:last-child td { border-bottom: none; }
.recon-table .sub-row td { padding: 4px var(--s5) 4px 40px; font-size: 12px; color: var(--text-2); }
.status-ok { color: var(--success); font-weight: 700; }
.status-warn { color: var(--warning); font-weight: 700; }
.status-ok-badge { background: var(--success-soft); color: var(--success); border-radius: 10px; padding: 2px 8px; font-size: 11px; font-weight: 700; }
.status-warn-badge { background: var(--warning-soft); color: var(--warning); border-radius: 10px; padding: 2px 8px; font-size: 11px; font-weight: 700; }

.tx-category-tags {
  display: flex; gap: var(--s2); flex-wrap: wrap;
  margin-bottom: var(--s4);
}
.tx-tag {
  display: flex; align-items: center; gap: var(--s1);
  padding: 4px 10px; border-radius: 20px;
  font-size: 12px; font-weight: 600; cursor: pointer;
  border: 2px solid transparent;
  transition: all .15s;
}
.tx-tag.active { border-color: currentColor; }

/* ─── SETTINGS ─── */
.settings-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: var(--s4);
  align-items: start;
}
.settings-card {
  background: var(--card); border-radius: var(--r3);
  box-shadow: var(--shadow-sm); border: 1px solid var(--border-light);
  padding: var(--s5);
}
.settings-card h3 {
  font-size: 14px; font-weight: 700; color: var(--text);
  margin-bottom: var(--s4); padding-bottom: var(--s3);
  border-bottom: 1px solid var(--border-light);
}
.tariffe-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--s3); }
.tariffa-item { display: flex; flex-direction: column; gap: var(--s1); }
.tariffa-label { font-size: 11px; font-weight: 700; color: var(--text-2); text-transform: uppercase; letter-spacing: .4px; }
.tariffa-input-wrap { display: flex; align-items: center; gap: var(--s1); }
.tariffa-input-wrap span { font-size: 13px; font-weight: 600; color: var(--text-2); }
.tariffa-input {
  flex: 1; padding: 7px var(--s2);
  border: 1.5px solid var(--border); border-radius: var(--r1);
  font-size: 14px; font-weight: 700; text-align: right;
  outline: none; transition: border-color .15s;
}
.tariffa-input:focus { border-color: var(--primary); }
.keyword-list { display: flex; flex-direction: column; gap: var(--s2); }
.keyword-row {
  display: flex; align-items: center; gap: var(--s2);
  padding: var(--s2) var(--s3);
  background: var(--gray-soft); border-radius: var(--r1);
  font-size: 12px;
}
.keyword-row-label { font-weight: 700; min-width: 80px; }
.keyword-val { flex: 1; font-family: monospace; color: var(--text-2); }

.data-actions { display: flex; flex-direction: column; gap: var(--s3); }
.data-action-row {
  display: flex; align-items: center; justify-content: space-between;
  padding: var(--s3) var(--s4);
  background: var(--gray-soft); border-radius: var(--r2);
}
.data-action-info { flex: 1; }
.data-action-title { font-size: 13px; font-weight: 600; color: var(--text); }
.data-action-sub { font-size: 12px; color: var(--text-2); }

/* ─── UTILITIES ─── */
.hidden { display: none !important; }
.mt1 { margin-top: var(--s1); }
.mt2 { margin-top: var(--s2); }
.mt3 { margin-top: var(--s3); }
.mt4 { margin-top: var(--s4); }
.flex { display: flex; }
.flex-center { display: flex; align-items: center; }
.gap2 { gap: var(--s2); }
.gap3 { gap: var(--s3); }
.gap4 { gap: var(--s4); }
.text-2 { color: var(--text-2); }
.text-sm { font-size: 12px; }
.font-bold { font-weight: 700; }
.w-full { width: 100%; }
.divider { height: 1px; background: var(--border-light); }

/* ─── TOASTS ─── */
#toast-container {
  position: fixed; bottom: var(--s6); right: var(--s6);
  z-index: 9999; display: flex; flex-direction: column; gap: var(--s2);
  pointer-events: none;
}
.toast {
  background: #1d1d1f; color: #fff;
  padding: 10px var(--s4); border-radius: var(--r2);
  font-size: 13px; font-weight: 500;
  box-shadow: var(--shadow-md);
  animation: slideUp .25s ease forwards;
  opacity: 0;
}
.toast.success { background: var(--success); }
.toast.error { background: var(--danger); }
@keyframes slideUp {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ─── CASH FLOW: ALTRE ENTRATE ─── */
.cf-other-card {
  background: #f9f9f9;
  border: 1.5px dashed #c8c8cc;
  border-radius: var(--r2);
  padding: var(--s4);
  margin-top: var(--s4);
}
.cf-other-header {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: var(--s3);
}
.cf-other-header h4 { margin: 0; color: var(--text-2); }
.cf-other-total { font-size: 13px; color: var(--text-2); }
.cf-other-list { display: flex; flex-direction: column; gap: 4px; }
.cf-other-row {
  display: grid; grid-template-columns: 80px 1fr 90px auto;
  align-items: start; gap: var(--s3);
  font-size: 12px; color: var(--text-2);
  padding: 6px 8px; border-radius: var(--r1);
  background: rgba(142,142,147,.08);
}
.cf-other-date { color: var(--text-3); font-size: 11px; white-space: nowrap; padding-top: 1px; }
.cf-other-desc { word-wrap: break-word; overflow-wrap: break-word; white-space: normal; line-height: 1.4; }
.cf-other-amt { text-align: right; font-weight: 500; color: var(--text); white-space: nowrap; }

/* ─── STARTUP BANNER ─── */
.startup-banner {
  display: flex; align-items: center; gap: var(--s3);
  background: #fff8e6; border-bottom: 1px solid #f0d080;
  padding: 12px var(--s6); position: relative;
  flex-wrap: wrap;
}
.startup-banner-icon { color: #c87f00; flex-shrink: 0; }
.startup-banner-text { flex: 1; font-size: 13px; color: var(--text); min-width: 180px; }
.startup-banner-actions { display: flex; gap: var(--s2); align-items: center; flex-wrap: wrap; }
.startup-banner-close {
  position: absolute; top: 10px; right: var(--s4);
  background: none; border: none; cursor: pointer; color: var(--text-2);
  padding: 2px; line-height: 1;
}
.startup-banner-close:hover { color: var(--text); }

/* ─── INLINE PAYMENT FORM (Day Panel) ─── */
.paga-inline-form {
  margin-top: 6px; padding: 8px 10px;
  background: var(--gray-soft); border-radius: var(--r1);
  border: 1px solid var(--border);
}
.paga-form-inner { display: flex; align-items: center; gap: var(--s2); flex-wrap: wrap; }
.paga-form-row select, .paga-form-row input { font-size: 12px; padding: 4px 8px; border: 1px solid var(--border); border-radius: var(--r1); }

/* ─── PATIENT PANEL PAY BUTTONS ─── */
.pp-pay-btn {
  font-size: 11px; font-weight: 600; padding: 3px 8px; border-radius: 6px;
  cursor: pointer; border: none; transition: all .15s;
}
.pp-pay-btn--paid { background: var(--success-soft); color: var(--success); }
.pp-pay-btn--paid:hover { background: var(--success); color: #fff; }
.pp-pay-btn--unpaid { background: var(--danger-soft); color: var(--danger); }
.pp-pay-btn--unpaid:hover { background: var(--danger); color: #fff; }
.pp-pay-met { font-size: 10px; color: var(--text-3); }
.pp-pay-dt { font-size: 10px; color: var(--text-3); }

/* ─── ASL CONFIRMED/EDIT MODE ─── */
.asl-row { display: flex; align-items: center; justify-content: space-between; margin-top: var(--s4); padding-top: var(--s4); border-top: 1px solid var(--border-light); }
.asl-row--confirmed { background: var(--success-soft); border-radius: var(--r2); padding: var(--s3) var(--s4); margin-top: var(--s4); border-top: none; }
.asl-edit-group { display: flex; align-items: center; gap: var(--s2); }
.asl-confirm-btn {
  padding: 5px 14px; font-size: 12px; font-weight: 600;
  background: var(--success); color: #fff; border: none; border-radius: var(--r1);
  cursor: pointer; transition: background .15s;
}
.asl-confirm-btn:hover { background: #2aad4a; }
.asl-confirmed-display { display: flex; align-items: center; gap: var(--s3); }
.asl-confirmed-value { font-size: 18px; font-weight: 700; color: var(--success); }
.asl-edit-btn { font-size: 12px; color: var(--primary); cursor: pointer; text-decoration: underline; background: none; border: none; }
.stepper { display: flex; align-items: center; gap: 2px; }
.step-btn {
  width: 30px; height: 30px; display: flex; align-items: center; justify-content: center;
  border-radius: 50%; border: 1px solid var(--border); background: var(--card);
  font-size: 16px; font-weight: 600; cursor: pointer; color: var(--text);
  transition: all .15s;
}
.step-btn:hover { background: var(--primary); color: #fff; border-color: var(--primary); }
.step-display { width: 48px; text-align: center; font-weight: 600; font-size: 14px; border: 1px solid var(--border); border-radius: var(--r1); padding: 4px; }

/* ─── REGISTRO CONTANTI ─── */
.registro-contanti-card {
  background: var(--card); border-radius: var(--r3); box-shadow: var(--shadow-sm);
  border: 1px solid var(--border-light); padding: var(--s5); margin-top: var(--s5);
}
.registro-contanti-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: var(--s3); }
.registro-contanti-icon { display: flex; align-items: center; gap: var(--s2); font-weight: 700; font-size: 15px; }
.registro-contanti-total { font-size: 13px; color: var(--text-2); }

/* ─── RECONCILIATION TABLE WIDE ─── */
.recon-table--wide th, .recon-table--wide td { font-size: 12px; }
.recon-cash-col { background: rgba(52,199,89,.05); }
.recon-cash-val { color: var(--success); font-weight: 600; }
.recon-main-row td { font-weight: 600; }

/* ─── CF CLASSIFY FORM ─── */
.cf-classify-trigger {
  font-size: 10px; padding: 2px 8px; border-radius: 10px;
  border: 1px solid var(--border); background: var(--card);
  color: var(--text-2); cursor: pointer; white-space: nowrap;
  transition: all .15s;
}
.cf-classify-trigger:hover { border-color: var(--primary); color: var(--primary); }
.cf-classify-form {
  margin-top: 6px; padding: var(--s3);
  background: #fff; border: 1px solid var(--border); border-radius: var(--r2);
  box-shadow: var(--shadow-sm);
}
.cf-classify-inner { display: flex; flex-direction: column; gap: var(--s3); }
.cf-classify-section-label { font-size: 11px; font-weight: 600; color: var(--text-2); text-transform: uppercase; letter-spacing: .5px; }
.cf-classify-existing { display: flex; flex-wrap: wrap; gap: 4px; }
.cf-classify-btn {
  font-size: 11px; padding: 3px 10px; border-radius: 10px;
  border: 1px solid var(--border); background: var(--card);
  cursor: pointer; transition: all .15s;
}
.cf-classify-btn:hover { border-color: var(--primary); background: var(--primary-soft); color: var(--primary); }
.cf-classify-newcat { display: flex; gap: var(--s2); align-items: center; }
.cf-classify-newcat input { flex: 1; font-size: 12px; padding: 4px 8px; border: 1px solid var(--border); border-radius: var(--r1); }
.cf-classify-cancel { font-size: 11px; color: var(--text-3); cursor: pointer; background: none; border: none; text-decoration: underline; }

/* Quick-action: suggerimento auto-categorizzazione */
.cf-classify-suggest { background: rgba(0,122,255,.04); border: 1px solid rgba(0,122,255,.18); border-radius: var(--r2); padding: var(--s2) var(--s3); }

/* FASE D2 — Stripe importer settings */
.stripe-card .stripe-warn { background: rgba(255,196,0,.08); border-left: 3px solid #ffc400; padding: var(--s3); border-radius: var(--r2); font-size: 13px; line-height: 1.5; margin: var(--s3) 0; }
.stripe-card .stripe-warn code { background: rgba(0,0,0,.06); padding: 1px 4px; border-radius: 3px; font-size: 12px; }
.stripe-form { display: flex; flex-direction: column; gap: var(--s3); }
.stripe-actions { display: flex; flex-wrap: wrap; gap: var(--s2); align-items: center; margin-top: var(--s2); }
.stripe-status { font-size: 12px; padding: var(--s2) var(--s3); background: var(--gray-soft); border-radius: var(--r2); margin-top: var(--s2); }
.stripe-help { margin-top: var(--s3); padding: var(--s2) var(--s3); background: var(--gray-soft); border-radius: var(--r2); font-size: 13px; }
.stripe-help summary { cursor: pointer; font-weight: 600; user-select: none; }
.stripe-help code { background: rgba(0,0,0,.06); padding: 1px 4px; border-radius: 3px; font-size: 12px; }
.cf-classify-suggest-btn { background: var(--primary-soft); color: var(--primary); border-color: rgba(0,122,255,.4); }
.cf-classify-suggest-btn:hover { background: var(--primary); color: #fff; }
.cf-classify-advanced summary { cursor: pointer; user-select: none; padding: 4px 0; }
.cf-classify-advanced[open] summary { margin-bottom: var(--s2); }
.cf-personal-tag {
  display: inline-block; font-size: 10px; padding: 1px 8px;
  background: var(--yellow-soft); color: #8a6d00; border-radius: 10px;
  font-weight: 600;
}

/* ─── CALENDAR BACKGROUND ─── */
.cal-wrap { position: relative; overflow-x: auto; }
.cal-wrap::before {
  content: ''; position: absolute; top: -40px; left: -60px;
  width: 280px; height: 280px; border-radius: 50%;
  background: radial-gradient(circle, rgba(0,122,255,.06) 0%, transparent 70%);
  pointer-events: none; z-index: 0;
}
.cal-wrap::after {
  content: ''; position: absolute; bottom: -30px; right: -40px;
  width: 220px; height: 220px; border-radius: 50%;
  background: radial-gradient(circle, rgba(52,199,89,.06) 0%, transparent 70%);
  pointer-events: none; z-index: 0;
}
.cal-wrap > .cal-grid { position: relative; z-index: 1; }
.cal-wrap > .cal-month-summary { position: relative; z-index: 1; }

/* ─── INFO BUTTON & TOOLTIP ─── */
.info-btn {
  display: inline-flex; align-items: center; justify-content: center;
  width: 18px; height: 18px; border-radius: 50%;
  background: var(--gray-soft); color: var(--text-3);
  font-size: 11px; font-weight: 700; cursor: pointer;
  border: none; transition: all .15s; vertical-align: middle;
  margin-left: 4px; line-height: 1;
}
.info-btn:hover { background: var(--primary-soft); color: var(--primary); }
.info-tooltip {
  position: fixed; z-index: 10000;
  max-width: 320px; padding: 12px 16px;
  background: #1d1d1f; color: #fff; border-radius: var(--r2);
  font-size: 12px; line-height: 1.5; box-shadow: var(--shadow-lg);
  pointer-events: auto;
}
.info-tooltip b { color: var(--teal); }

/* ─── GUIDE PAGE ─── */
.guide-page { max-width: 800px; margin: 0 auto; }
.guide-hero {
  text-align: center; padding: var(--s8) var(--s6);
  background: linear-gradient(135deg, rgba(0,122,255,.08), rgba(52,199,89,.08));
  border-radius: var(--r4); margin-bottom: var(--s6);
}
.guide-hero-mascot { font-size: 48px; margin-bottom: var(--s3); }
.guide-hero h2 { font-size: 24px; font-weight: 700; margin-bottom: var(--s2); }
.guide-hero p { font-size: 14px; color: var(--text-2); }
.guide-sections { display: flex; flex-direction: column; gap: var(--s3); }
.guide-section {
  background: var(--card); border-radius: var(--r3);
  box-shadow: var(--shadow-sm); border: 1px solid var(--border-light);
  overflow: hidden;
}
.guide-section-header {
  display: flex; align-items: center; gap: var(--s3);
  padding: var(--s4) var(--s5); cursor: pointer;
  transition: background .15s;
}
.guide-section-header:hover { background: var(--gray-soft); }
.guide-section-icon { font-size: 20px; flex-shrink: 0; }
.guide-section-header h3 { flex: 1; font-size: 15px; font-weight: 600; }
.guide-section-header .chevron {
  transition: transform .2s; color: var(--text-3); font-size: 18px;
}
.guide-section.open .guide-section-header .chevron { transform: rotate(90deg); }
.guide-section-body {
  display: none; padding: 0 var(--s5) var(--s5);
  font-size: 13px; line-height: 1.7; color: var(--text-2);
}
.guide-section.open .guide-section-body { display: block; }
.guide-steps { list-style: none; padding: 0; margin: var(--s3) 0; display: flex; flex-direction: column; gap: var(--s3); }
.guide-step { display: flex; gap: var(--s3); align-items: flex-start; }
.guide-step-num {
  width: 26px; height: 26px; border-radius: 50%;
  background: var(--primary); color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 700; flex-shrink: 0;
}
.guide-step-text { flex: 1; }
.guide-tip {
  background: var(--primary-soft); border-left: 3px solid var(--primary);
  padding: var(--s3) var(--s4); border-radius: 0 var(--r1) var(--r1) 0;
  margin: var(--s3) 0; font-size: 12px;
}
.guide-warn {
  background: var(--warning-soft); border-left: 3px solid var(--warning);
  padding: var(--s3) var(--s4); border-radius: 0 var(--r1) var(--r1) 0;
  margin: var(--s3) 0; font-size: 12px;
}
.guide-glossary {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: var(--s3); margin-top: var(--s3);
}
.guide-gloss-item {
  padding: var(--s3); background: var(--gray-soft);
  border-radius: var(--r2); text-align: center;
}
.guide-gloss-item .badge { font-size: 14px; }
.guide-gloss-item .price { font-size: 18px; font-weight: 700; margin: 4px 0; }
.guide-gloss-item p:last-child { font-size: 11px; color: var(--text-2); }

/* ═══════════════════════════════════════════════════════════════
   ANDAMENTO TAB — Performance dashboard
   ═══════════════════════════════════════════════════════════════ */

.and-page {
  display: flex; flex-direction: column; gap: var(--s5);
}

.and-section-title {
  font-size: 14px; font-weight: 700; color: var(--text);
  margin: var(--s3) 0 var(--s2) 2px;
  display: flex; align-items: center; gap: 8px;
  letter-spacing: -.2px;
}
.and-section-title .and-section-sub {
  font-size: 11px; font-weight: 500; color: var(--text-3);
}

/* KPI cards row (Block 4) — 3 colonne (era 4) */
.kpi-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--s4);
}
.kpi-card {
  background: var(--card); border: 1px solid var(--border-light);
  border-radius: var(--r3); box-shadow: var(--shadow-sm);
  padding: var(--s5) var(--s5) var(--s4);
  display: flex; flex-direction: column;
  gap: 6px;
  position: relative; overflow: hidden;
  min-height: 130px;
}
.kpi-card::before {
  content: ''; position: absolute; left: 0; top: 0; bottom: 0;
  width: 3px; background: var(--c-accent, var(--primary));
}
.kpi-card.kpi--ore        { --c-accent: var(--primary); }
.kpi-card.kpi--gratis     { --c-accent: var(--c-ubg); }
.kpi-card.kpi--orario     { --c-accent: var(--success); }
.kpi-card.kpi--unbillable { --c-accent: var(--warning); }
.kpi-label {
  font-size: 11px; font-weight: 700; color: var(--text-2);
  text-transform: uppercase; letter-spacing: .5px;
}
.kpi-value {
  font-size: 30px; font-weight: 700; color: var(--text);
  letter-spacing: -.6px; line-height: 1.05;
  margin-top: 2px;
  font-variant-numeric: tabular-nums;
}
.kpi-sub {
  font-size: 11px; color: var(--text-3);
  margin-top: auto;
}

/* Weekly chart card (Block 1, Block 4) */
.weekly-chart-card {
  background: var(--card); border: 1px solid var(--border-light);
  border-radius: var(--r3); box-shadow: var(--shadow-sm);
  padding: var(--s5);
}
.weekly-chart-card .wcc-head {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: var(--s4); flex-wrap: wrap; gap: var(--s3);
}
.weekly-chart-card h4 {
  font-size: 13px; font-weight: 700; color: var(--text); letter-spacing: -.2px;
  display: flex; align-items: center; gap: 6px;
}
.weekly-chart-card .wcc-controls {
  display: flex; align-items: center; gap: var(--s2); font-size: 12px;
}
.range-toggle {
  display: inline-flex; background: var(--gray-soft);
  border-radius: var(--r1); padding: 2px;
}
.range-toggle button {
  border: none; background: transparent;
  padding: 4px 10px; font-size: 11px; font-weight: 600;
  color: var(--text-2); cursor: pointer; border-radius: 5px;
  transition: all .15s;
}
.range-toggle button.active {
  background: var(--card); color: var(--text);
  box-shadow: var(--shadow-xs);
}
.weekly-chart-wrap { position: relative; height: 280px; }

/* Two-column layout (Target calculator + Active patients) */
.and-two-col {
  display: grid; grid-template-columns: 1.2fr 1fr; gap: var(--s4);
}

/* Target calculator (Block 2) */
.target-calc-card {
  background: var(--card); border: 1px solid var(--border-light);
  border-radius: var(--r3); box-shadow: var(--shadow-sm);
  padding: var(--s5);
  display: flex; flex-direction: column; gap: var(--s4);
}
.target-calc-card h4 {
  font-size: 13px; font-weight: 700; color: var(--text); letter-spacing: -.2px;
  display: flex; align-items: center; gap: 6px;
}
.tc-row {
  display: flex; flex-direction: column; gap: 6px;
}
.tc-row-head {
  display: flex; align-items: center; justify-content: space-between;
  font-size: 12px; color: var(--text-2); font-weight: 600;
}
.tc-row-head .tc-value {
  font-size: 13px; color: var(--text); font-weight: 700;
  font-variant-numeric: tabular-nums;
}
.tc-input-wrap {
  display: flex; align-items: center; gap: var(--s2);
  background: var(--gray-soft); border-radius: var(--r2);
  padding: 4px 4px 4px 12px;
}
.tc-input-wrap > span { font-size: 13px; color: var(--text-2); font-weight: 600; }
.tc-input {
  flex: 1; border: none; background: transparent;
  font-size: 14px; font-weight: 700; color: var(--text);
  padding: 6px 4px; outline: none;
  font-variant-numeric: tabular-nums;
}
.tc-slider {
  -webkit-appearance: none; appearance: none;
  width: 100%; height: 6px; border-radius: 3px;
  background: linear-gradient(to right, var(--primary) var(--p,50%), var(--success) var(--p,50%));
  outline: none; cursor: pointer;
}
.tc-slider::-webkit-slider-thumb {
  -webkit-appearance: none; appearance: none;
  width: 18px; height: 18px; border-radius: 50%;
  background: var(--card); border: 2px solid var(--text);
  cursor: pointer; box-shadow: var(--shadow-xs);
}
.tc-slider::-moz-range-thumb {
  width: 18px; height: 18px; border-radius: 50%;
  background: var(--card); border: 2px solid var(--text);
  cursor: pointer;
}

.tc-mix-labels {
  display: flex; justify-content: space-between;
  font-size: 11px; font-weight: 600; color: var(--text-2);
  margin-top: 2px;
}
.tc-mix-labels .tc-mix-priv { color: var(--primary); }
.tc-mix-labels .tc-mix-ub   { color: var(--success); }

.tc-prices-row {
  display: grid; grid-template-columns: 1fr 1fr; gap: var(--s3);
}
.tc-price-cell {
  display: flex; flex-direction: column; gap: 2px;
}
.tc-price-cell .tc-price-lbl {
  font-size: 10px; color: var(--text-3); font-weight: 600;
  text-transform: uppercase; letter-spacing: .3px;
}

.tc-result {
  background: linear-gradient(135deg, var(--primary-soft), var(--success-soft));
  border-radius: var(--r2); padding: var(--s4);
  display: grid; grid-template-columns: 1fr 1fr 1fr; gap: var(--s3);
}
.tc-result-cell {
  display: flex; flex-direction: column; gap: 2px;
  text-align: center;
}
.tc-result-cell .tc-r-lbl {
  font-size: 10px; color: var(--text-2); font-weight: 600;
  text-transform: uppercase; letter-spacing: .3px;
}
.tc-result-cell .tc-r-val {
  font-size: 22px; font-weight: 700; color: var(--text);
  letter-spacing: -.4px; font-variant-numeric: tabular-nums;
}
.tc-result-cell .tc-r-sub {
  font-size: 10px; color: var(--text-2);
}

/* FASE C — Pianificatore unificato: toggle modalità e box status/fiscale */
.tc-mode-toggle {
  display: inline-flex; gap: 4px; background: var(--gray-soft); border-radius: var(--r2);
  padding: 3px; margin-bottom: var(--s3);
}
.tc-mode-toggle button {
  font-size: 12px; padding: 6px 12px; border: none; background: transparent;
  border-radius: calc(var(--r2) - 3px); cursor: pointer; font-weight: 500; color: var(--text-2);
}
.tc-mode-toggle button.active { background: #fff; color: var(--text); box-shadow: var(--shadow-sm); font-weight: 600; }

.tc-status, .tc-fiscal {
  margin-top: var(--s3); padding: var(--s3) var(--s4);
  border: 1px solid var(--border); border-radius: var(--r2); background: #fff;
}
.tc-status-head, .tc-fiscal-head {
  font-size: 12px; font-weight: 700; color: var(--text); margin-bottom: var(--s2);
  display: flex; align-items: center; gap: 6px;
}
.tc-status-grid, .tc-fiscal-grid {
  display: grid; grid-template-columns: 1fr 1fr 1fr; gap: var(--s2);
}
.tc-status-cell, .tc-fiscal-cell {
  display: flex; flex-direction: column; gap: 2px; padding: 6px 8px;
  border-radius: var(--r1); background: var(--gray-soft);
}
.tc-status-cell .tc-r-lbl, .tc-fiscal-cell .tc-r-lbl {
  font-size: 10px; color: var(--text-2); font-weight: 600; text-transform: uppercase; letter-spacing: .3px;
}
.tc-status-cell .tc-r-val, .tc-fiscal-cell .tc-r-val {
  font-size: 18px; font-weight: 700; color: var(--text); font-variant-numeric: tabular-nums;
}
.tc-status-cell .tc-r-sub, .tc-fiscal-cell .tc-r-sub {
  font-size: 10px; color: var(--text-2);
}
.tc-status-on_track { background: rgba(52,199,89,.10); }
.tc-status-on_track .tc-r-val { color: #2a8a3a; }
.tc-status-behind { background: rgba(255,59,48,.08); }
.tc-status-behind .tc-r-val { color: #a8281a; }
.tc-status-ahead { background: rgba(0,122,255,.08); }
.tc-status-ahead .tc-r-val { color: #006fd6; }
.tc-fiscal-cell--netto { background: linear-gradient(135deg, var(--primary-soft), var(--success-soft)); }
.tc-fiscal-cell--netto .tc-r-val { color: #006fd6; font-size: 22px; }

@media (max-width: 720px) {
  .tc-status-grid, .tc-fiscal-grid { grid-template-columns: 1fr; }
}

.tc-note {
  font-size: 11px; color: var(--text-3); line-height: 1.5;
  padding: var(--s2) var(--s3); background: var(--warning-soft);
  border-radius: var(--r1); border-left: 3px solid var(--warning);
}

.tc-save-row {
  display: flex; justify-content: flex-end; gap: var(--s2);
}

/* Active patients (Block 3) */
.active-pts-card {
  background: var(--card); border: 1px solid var(--border-light);
  border-radius: var(--r3); box-shadow: var(--shadow-sm);
  padding: var(--s5);
  display: flex; flex-direction: column; gap: var(--s4);
  min-height: 0;
}
.active-pts-card h4 {
  font-size: 13px; font-weight: 700; color: var(--text); letter-spacing: -.2px;
  display: flex; align-items: center; gap: 6px;
}
.active-pts-summary {
  display: grid; grid-template-columns: auto 1fr; gap: var(--s4);
  align-items: center;
}
.active-pts-bignum {
  font-size: 44px; font-weight: 700; color: var(--text);
  line-height: 1; letter-spacing: -1px; font-variant-numeric: tabular-nums;
}
.active-pts-bignum-lbl {
  font-size: 11px; color: var(--text-2); font-weight: 600;
  margin-top: 4px; text-transform: uppercase; letter-spacing: .3px;
}
.active-pts-breakdown {
  display: flex; flex-direction: column; gap: 6px;
}
.active-pts-bd-row {
  display: flex; align-items: center; gap: var(--s2);
  font-size: 12px;
}
.active-pts-bd-dot {
  width: 8px; height: 8px; border-radius: 50%;
  flex-shrink: 0;
}
.active-pts-bd-row .bd-label { flex: 1; color: var(--text-2); font-weight: 500; }
.active-pts-bd-row .bd-count { color: var(--text); font-weight: 700; font-variant-numeric: tabular-nums; }

.active-pts-list {
  display: flex; flex-direction: column; gap: 0;
  max-height: 320px; overflow-y: auto;
  border-top: 1px solid var(--border-light);
  margin: 0 calc(-1 * var(--s5));
  padding: 0 var(--s5);
}
.active-pts-row {
  display: grid; grid-template-columns: 1fr auto auto;
  gap: var(--s3); align-items: center;
  padding: var(--s3) 0;
  border-bottom: 1px solid var(--border-light);
  cursor: pointer;
  transition: background .12s;
}
.active-pts-row:hover { background: var(--gray-soft); margin: 0 calc(-1 * var(--s2)); padding-left: var(--s2); padding-right: var(--s2); border-radius: var(--r1); }
.active-pts-row:last-child { border-bottom: none; }
.active-pts-row .apr-name {
  font-size: 13px; font-weight: 600; color: var(--text);
  display: flex; align-items: center; gap: 8px;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.active-pts-row .apr-cnt {
  font-size: 12px; font-weight: 700; color: var(--text);
  font-variant-numeric: tabular-nums;
}
.active-pts-row .apr-last {
  font-size: 11px; color: var(--text-3);
  font-variant-numeric: tabular-nums;
}
.active-pts-empty {
  text-align: center; padding: var(--s6) var(--s4);
  color: var(--text-3); font-size: 13px;
}

/* ═══════════════════════════════════════════════════════════════
   CRM v2 — Enriched patient table (LCV + Mese corrente)
   ═══════════════════════════════════════════════════════════════ */

/* Wider table to accommodate new columns + ottimizzazione larghezze */
.patient-table--rich {
  table-layout: auto;
}
.patient-table--rich th,
.patient-table--rich td {
  font-size: 12.5px;
  white-space: nowrap;
}
.patient-table--rich .th-sort { cursor: pointer; user-select: none; }
.patient-table--rich .th-sort:hover { color: var(--text); }
.patient-table--rich .th-action { width: 36px; }

/* Larghezze ottimizzate: stringi le colonne meno informative,
   espandi la colonna Sedute (mini-bar) */
.patient-table--rich th:nth-child(1),
.patient-table--rich td:nth-child(1) { width: 20%; }                 /* Nome */
.patient-table--rich th:nth-child(2),
.patient-table--rich td:nth-child(2) { width: 90px; }                /* Tipologia */
.patient-table--rich th:nth-child(3),
.patient-table--rich td:nth-child(3) { width: 70px; }                /* Canale */
.patient-table--rich th:nth-child(4),
.patient-table--rich td:nth-child(4) { width: 90px; }                /* Stato */
.patient-table--rich th:nth-child(5),
.patient-table--rich td:nth-child(5) { width: 26%; }                 /* Sedute (con mini-bar) */
.patient-table--rich th:nth-child(6),
.patient-table--rich td:nth-child(6) { width: 90px; text-align: center; }   /* LCV */
.patient-table--rich th:nth-child(7),
.patient-table--rich td:nth-child(7) { width: 110px; text-align: center; }  /* Mese corrente */
.patient-table--rich th:nth-child(8),
.patient-table--rich td:nth-child(8) { width: 90px; }                /* Ultima */
.patient-table--rich th:nth-child(9),
.patient-table--rich td:nth-child(9) { width: 80px; }                /* Non pagate */

/* Mini bar inline col Sedute (più larga) */
.td-sedute { min-width: 200px; }
.pt-sed-bar-wrap {
  display: flex; align-items: center; gap: var(--s2);
  height: 18px;
}
.pt-sed-bar {
  flex: 1; height: 14px; border-radius: 3px;
  background: var(--gray-soft); overflow: hidden;
  min-width: 100px;
}
.pt-sed-bar-fill {
  height: 100%; border-radius: 3px;
  transition: width .3s;
}
.pt-sed-bar-fill.canale-UB   { background: rgba(52,199,89,.85); }
.pt-sed-bar-fill.canale-CCNP { background: rgba(88,86,214,.85); }
.pt-sed-bar-fill.canale-priv { background: rgba(0,122,255,.85); }
.pt-sed-cnt {
  font-size: 13px; font-weight: 700; color: var(--text);
  min-width: 22px; text-align: right;
  font-variant-numeric: tabular-nums;
}

/* Money cells (LCV, Mese corrente) — più grandi e centrati */
.td-money {
  text-align: center;
  font-variant-numeric: tabular-nums;
  font-weight: 700; color: var(--text);
  font-size: 14px;
  letter-spacing: -.2px;
}
.td-money.is-zero { color: var(--text-3); font-weight: 500; }

/* Action column: Chiudi/Riapri terapia */
.td-action {
  text-align: center; width: 36px;
  padding: 0 var(--s2) !important;
}
.pt-action-btn {
  width: 26px; height: 26px;
  border: 1px solid var(--border);
  background: var(--card);
  border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--text-2); cursor: pointer;
  opacity: 0; visibility: hidden;
  transition: all .15s;
  padding: 0;
}
.patient-table--rich tr:hover .pt-action-btn,
.patient-table--rich .pt-row-closed .pt-action-btn {
  opacity: 1; visibility: visible;
}
.pt-action-btn:hover {
  background: var(--danger-soft);
  border-color: var(--danger);
  color: var(--danger);
}
.pt-action-btn--reopen:hover {
  background: var(--success-soft);
  border-color: var(--success);
  color: var(--success);
}

/* Closed therapy: row visually subdued */
.patient-table--rich .pt-row-closed td {
  background: var(--gray-soft);
  opacity: .65;
}
.patient-table--rich .pt-row-closed:hover td {
  opacity: .9;
  background: var(--gray-soft);
}
.patient-table--rich .pt-row-closed .pt-name {
  text-decoration: line-through;
  text-decoration-color: var(--text-3);
}

/* ─── UB Conversion card ─── */
.ub-conv-head {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: var(--s2); flex-wrap: wrap; gap: var(--s2);
}
.ub-conv-toggle button {
  font-size: 10.5px;
  padding: 3px 9px;
}
.ub-conv-wrap {
  height: 170px;
  display: flex; align-items: center;
}
.ub-conv-empty {
  width: 100%; text-align: center; color: var(--text-3); font-size: 13px;
  padding: var(--s5) var(--s4);
}
/* Layout INVERTITO: stats a sinistra, chart a destra */
.ub-conv-grid {
  display: grid;
  grid-template-columns: 1fr 140px;
  gap: var(--s4);
  width: 100%; align-items: center;
}
.ub-conv-chart-side {
  position: relative;
  height: 140px; width: 140px;
  justify-self: end;
}
.ub-conv-canvas-wrap {
  position: relative; width: 100%; height: 100%;
}
.ub-conv-center {
  position: absolute; top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  text-align: center; pointer-events: none;
}
.ub-conv-pct {
  font-size: 26px; font-weight: 700; color: var(--text);
  letter-spacing: -.5px; line-height: 1;
}
.ub-conv-pct-lbl {
  font-size: 10px; color: var(--text-2); font-weight: 600;
  text-transform: uppercase; letter-spacing: .3px;
  margin-top: 2px;
}
.ub-conv-period {
  font-size: 10px; font-weight: 600; color: var(--text-3);
  text-transform: uppercase; letter-spacing: .4px;
  margin-bottom: 2px;
}
.ub-conv-stats {
  display: flex; flex-direction: column; gap: var(--s2);
  min-width: 0;
}
.ub-conv-stat {
  border-left: 3px solid;
  padding: 6px var(--s3);
  display: grid;
  grid-template-columns: auto 1fr;
  gap: var(--s3); align-items: center;
  border-radius: 0 var(--r1) var(--r1) 0;
  transition: background .15s, transform .15s;
  cursor: default;
}
.ub-conv-stat--ok   { border-color: var(--success); }
.ub-conv-stat--warn { border-color: var(--warning); }
.ub-conv-stat.is-active {
  background: rgba(0,0,0,.03);
  transform: translateX(2px);
}
.ub-conv-stat--ok.is-active   { background: var(--success-soft); }
.ub-conv-stat--warn.is-active { background: var(--warning-soft); }
.ub-conv-stat-num {
  font-size: 26px; font-weight: 700; color: var(--text);
  font-variant-numeric: tabular-nums; line-height: 1;
}
.ub-conv-stat-info {
  display: flex; flex-direction: column; gap: 2px;
  min-width: 0;
}
.ub-conv-stat-lbl {
  font-size: 12px; font-weight: 700; color: var(--text);
}
.ub-conv-stat-sub {
  font-size: 10.5px; color: var(--text-3);
  font-weight: 500;
}

/* ─── KPI doppio valore (Sett/Mese) ─── */
.kpi-card .kpi-value .kpi-unit {
  font-size: 13px; font-weight: 600;
  color: var(--text-2);
  margin-left: 3px;
  letter-spacing: 0;
}
.kpi-month-line {
  font-size: 11.5px; color: var(--text-2);
  margin-top: 2px; font-weight: 500;
}
.kpi-month-line b {
  color: var(--text); font-weight: 700;
  font-variant-numeric: tabular-nums;
}

/* ─── Target calc: ASL line in result box ─── */
.tc-r-asl {
  grid-column: 1 / -1;
  font-size: 11px; color: var(--text-2);
  background: rgba(255,149,0,.12);
  border-left: 3px solid var(--warning);
  padding: 6px 10px;
  border-radius: 4px;
  margin-bottom: var(--s2);
  font-variant-numeric: tabular-nums;
}
.tc-r-asl b { color: var(--text); font-weight: 700; }
.tc-result-grid {
  grid-column: 1 / -1;
  display: grid; grid-template-columns: 1fr 1fr 1fr; gap: var(--s3);
}
.tc-result {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
}

/* ─── Toast with action button (undo) ─── */
.toast--action {
  display: flex; align-items: center;
  gap: var(--s3); padding: 8px 8px 8px var(--s4);
  pointer-events: auto;
}
.toast--action .toast-msg {
  flex: 1;
}
.toast-action-btn {
  background: rgba(255,255,255,.18);
  border: none;
  color: #fff;
  padding: 6px 12px;
  border-radius: 6px;
  font-size: 12px; font-weight: 700;
  cursor: pointer;
  transition: background .15s;
  text-transform: uppercase;
  letter-spacing: .3px;
  font-family: inherit;
}
.toast-action-btn:hover { background: rgba(255,255,255,.32); }

/* Responsive: tablet/mobile */
@media (max-width: 980px) {
  .kpi-grid { grid-template-columns: repeat(2, 1fr); }
  .and-two-col { grid-template-columns: 1fr; }
  .tc-result-grid { grid-template-columns: 1fr; gap: var(--s2); }
  .tc-result-cell { flex-direction: row; justify-content: space-between; text-align: left; }
  .ub-conv-grid { grid-template-columns: 1fr !important; gap: var(--s3); }
  .ub-conv-chart-side { margin: 0 auto; }
  /* Hide some columns on narrow screens */
  .patient-table--rich th:nth-child(2),
  .patient-table--rich td:nth-child(2),
  .patient-table--rich th:nth-child(8),
  .patient-table--rich td:nth-child(8) { display: none; }
}
@media (max-width: 720px) {
  .kpi-grid { grid-template-columns: 1fr; }
  .patient-table--rich th:nth-child(9),
  .patient-table--rich td:nth-child(9) { display: none; }
  .pt-sed-bar { display: none; }
  .pt-action-btn { opacity: 1; visibility: visible; }
}

/* ═══════════════════════════════════════════════════════════
   TAB FISCALITÀ — M1+M2+M3+M6
   ═══════════════════════════════════════════════════════════ */
.fisc-page { max-width: 1280px; margin: 0 auto; padding: var(--s2) 0; }
.fisc-hero { display: flex; justify-content: space-between; align-items: flex-start; gap: var(--s4); margin-bottom: var(--s5); padding: var(--s5); border-radius: var(--r3); background: linear-gradient(135deg, #f0f7ff 0%, #f5f0ff 100%); border: 1px solid var(--border-light); }
.fisc-hero-title h2 { font-size: 22px; font-weight: 700; margin: 0 0 4px; color: var(--text); }
.fisc-hero-title p { font-size: 13px; color: var(--text-2); margin: 0; }
.fisc-hero-disclaimer { background: rgba(255,255,255,.6); padding: var(--s2) var(--s3); border-radius: var(--r2); font-size: 11px; color: var(--text-2); border: 1px solid rgba(0,0,0,.04); flex-shrink: 0; max-width: 260px; }
.fisc-grid { display: grid; grid-template-columns: 1fr 1.4fr; gap: var(--s4); margin-bottom: var(--s4); }
@media (max-width: 980px) { .fisc-grid { grid-template-columns: 1fr; } }
.fisc-col { display: flex; flex-direction: column; gap: var(--s4); }
.fisc-card { background: var(--card); border: 1px solid var(--border); border-radius: var(--r3); padding: var(--s5); box-shadow: var(--shadow-xs); }
.fisc-card--full { grid-column: 1 / -1; margin-bottom: var(--s4); }
.fisc-card--accent { background: linear-gradient(135deg, #ffffff 0%, #f5faff 100%); border-color: #d6e6f7; }
.fisc-card h3 { margin: 0 0 4px; font-size: 16px; font-weight: 700; color: var(--text); }
.fisc-card h4.fisc-section-h4 { margin: var(--s5) 0 var(--s2); font-size: 13px; font-weight: 600; color: var(--text-2); text-transform: uppercase; letter-spacing: .5px; }
.fisc-card-sub { font-size: 12px; color: var(--text-2); margin: 0 0 var(--s4); }
.fisc-form { display: flex; flex-direction: column; gap: var(--s3); }
.fisc-form-row { display: flex; flex-direction: column; gap: 4px; }
.fisc-form-row label { font-size: 12px; font-weight: 600; color: var(--text-2); }
.fisc-input, .fisc-form-row select.fisc-input { appearance: none; -webkit-appearance: none; border: 1px solid var(--border); border-radius: var(--r2); padding: 8px 12px; font-size: 14px; font-family: inherit; background: var(--card); color: var(--text); width: 100%; transition: border .15s, box-shadow .15s; }
.fisc-input:focus { outline: none; border-color: var(--primary); box-shadow: 0 0 0 3px var(--primary-soft); }
.fisc-input--big { font-size: 18px; font-weight: 700; padding: 10px 14px; }
.fisc-hint { font-size: 11px; color: var(--text-3); margin-top: 2px; }
.fisc-hint--ok { color: var(--success); font-weight: 600; }
.fisc-input-with-suffix { position: relative; display: flex; align-items: center; }
.fisc-input-with-suffix span { position: absolute; right: 12px; font-size: 13px; color: var(--text-3); pointer-events: none; }
.fisc-input-with-suffix .fisc-input { padding-right: 28px; }
.fisc-input-with-suffix--euro span { left: 12px; right: auto; font-weight: 600; color: var(--text-2); }
.fisc-input-with-suffix--euro .fisc-input { padding-left: 28px; padding-right: 12px; }
.fisc-radio-group { display: flex; gap: var(--s2); }
.fisc-radio { flex: 1; display: flex; align-items: center; justify-content: center; gap: var(--s2); padding: 10px 14px; border: 1px solid var(--border); border-radius: var(--r2); cursor: pointer; transition: all .15s; background: var(--card); }
.fisc-radio input { appearance: none; width: 14px; height: 14px; border-radius: 50%; border: 2px solid var(--border); margin: 0; position: relative; }
.fisc-radio.active { background: var(--primary-soft); border-color: var(--primary); }
.fisc-radio.active input { border-color: var(--primary); }
.fisc-radio.active input::after { content: ''; position: absolute; inset: 2px; border-radius: 50%; background: var(--primary); }
.fisc-radio span { font-size: 14px; font-weight: 600; color: var(--text); }
.fisc-switch { display: flex; align-items: center; gap: var(--s2); cursor: pointer; padding: 4px 0; }
.fisc-switch input { width: 16px; height: 16px; accent-color: var(--primary); cursor: pointer; }
.fisc-switch-label { font-size: 13px; color: var(--text); }
.fisc-spese { margin-top: var(--s4); padding-top: var(--s4); border-top: 1px solid var(--border-light); }
.fisc-spese h4 { margin: 0 0 4px; font-size: 14px; font-weight: 700; }
.fisc-spesa-row { display: grid; grid-template-columns: 1.2fr 1fr 1.4fr; gap: var(--s2); align-items: center; padding: var(--s2) 0; }
.fisc-spesa-row label { font-size: 13px; color: var(--text); font-weight: 500; }
.fisc-spesa-row .fisc-hint { margin: 0; }
.fisc-spese-tot { margin-top: var(--s3); padding-top: var(--s3); border-top: 1px dashed var(--border); font-size: 14px; text-align: right; color: var(--text-2); }
.fisc-spese-tot b { color: var(--text); font-size: 16px; }
.fisc-scenario-header { display: flex; justify-content: space-between; align-items: flex-start; gap: var(--s3); margin-bottom: var(--s4); }
.fisc-btn-secondary { font-size: 12px; padding: 6px 10px; border: 1px solid var(--border); background: var(--card); border-radius: var(--r2); cursor: pointer; color: var(--text-2); transition: all .15s; }
.fisc-btn-secondary:hover { background: var(--gray-soft); color: var(--text); }
.fisc-scenario-input { display: flex; flex-direction: column; gap: var(--s3); }
.fisc-slider { width: 100%; -webkit-appearance: none; appearance: none; height: 6px; background: var(--gray-soft); border-radius: 3px; outline: none; }
.fisc-slider::-webkit-slider-thumb { -webkit-appearance: none; appearance: none; width: 20px; height: 20px; border-radius: 50%; background: var(--primary); cursor: pointer; box-shadow: var(--shadow-sm); }
.fisc-slider::-moz-range-thumb { width: 20px; height: 20px; border-radius: 50%; background: var(--primary); cursor: pointer; border: none; }
.fisc-kpi-row { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: var(--s3); margin: var(--s4) 0 var(--s3); }
.fisc-kpi { padding: var(--s4); border-radius: var(--r3); background: var(--gray-soft); border: 1px solid transparent; }
.fisc-kpi-label { font-size: 11px; font-weight: 600; color: var(--text-2); text-transform: uppercase; letter-spacing: .4px; margin-bottom: 6px; }
.fisc-kpi-value { font-size: 26px; font-weight: 700; color: var(--text); line-height: 1.1; }
.fisc-kpi-sub { font-size: 11px; color: var(--text-2); margin-top: 4px; }
.fisc-kpi--tax  { background: var(--danger-soft); }
.fisc-kpi--tax .fisc-kpi-value { color: #C62828; }
.fisc-kpi--net  { background: var(--success-soft); }
.fisc-kpi--net .fisc-kpi-value { color: #1B5E20; }
.fisc-kpi--info { background: var(--primary-soft); }
.fisc-kpi--info .fisc-kpi-value { color: #0A4DA2; }
.fisc-breakdown { width: 100%; border-collapse: collapse; margin-top: var(--s3); background: var(--card); border-radius: var(--r2); overflow: hidden; border: 1px solid var(--border-light); }
.fisc-breakdown th, .fisc-breakdown td { padding: 10px 14px; text-align: left; font-size: 13px; border-bottom: 1px solid var(--border-light); }
.fisc-breakdown thead th { background: var(--gray-soft); color: var(--text-2); font-size: 11px; text-transform: uppercase; letter-spacing: .4px; font-weight: 600; }
.fisc-breakdown tfoot th { background: #fafafc; font-weight: 700; color: var(--text); border-top: 2px solid var(--border); }
.fisc-breakdown tbody tr:last-child td { border-bottom: 0; }
.fisc-num { text-align: right !important; font-variant-numeric: tabular-nums; }
.fisc-pct { color: var(--text-2); font-size: 12px; }
.fisc-tag { display: inline-block; padding: 2px 8px; font-size: 11px; font-weight: 600; border-radius: 999px; vertical-align: middle; }
.fisc-tag--ok     { background: var(--success-soft); color: #1B5E20; }
.fisc-tag--warn   { background: var(--warning-soft); color: #B25E00; }
.fisc-tag--danger { background: var(--danger-soft);  color: #C62828; }
.fisc-formula { margin-top: var(--s3); padding: var(--s3); background: #f8fafc; border-left: 3px solid var(--primary); border-radius: 0 var(--r2) var(--r2) 0; font-size: 13px; color: var(--text-2); line-height: 1.5; font-family: ui-monospace, 'SF Mono', Menlo, Consolas, monospace; }
.fisc-formula b { color: var(--text); font-weight: 700; }
.fisc-accantonamento { display: flex; gap: var(--s3); align-items: center; margin-top: var(--s4); padding: var(--s4); background: linear-gradient(135deg, #fff8e1 0%, #ffecb3 100%); border-radius: var(--r3); border: 1px solid #f0c040; }
.fisc-accantonamento-icon { font-size: 32px; flex-shrink: 0; }
.fisc-accantonamento-title { font-size: 12px; font-weight: 600; color: #8d6e00; text-transform: uppercase; letter-spacing: .4px; }
.fisc-accantonamento-value { font-size: 28px; font-weight: 800; color: #5d4900; line-height: 1.1; margin: 4px 0; }
.fisc-accantonamento-sub { font-size: 12px; color: #8d6e00; }
.fisc-seduta-row { display: grid; grid-template-columns: 1fr 1.4fr; gap: var(--s4); align-items: end; margin-bottom: var(--s2); }
@media (max-width: 720px) { .fisc-seduta-row { grid-template-columns: 1fr; } }
.fisc-seduta-input label { font-size: 12px; font-weight: 600; color: var(--text-2); display: block; margin-bottom: 4px; }
.fisc-seduta-presets { display: flex; gap: var(--s2); flex-wrap: wrap; }
.fisc-preset { padding: 8px 14px; border: 1px solid var(--border); background: var(--card); border-radius: var(--r2); cursor: pointer; font-size: 13px; font-weight: 600; color: var(--text-2); transition: all .15s; }
.fisc-preset:hover { background: var(--gray-soft); color: var(--text); }
.fisc-preset.active { background: var(--primary); color: white; border-color: var(--primary); }
.fisc-note-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: var(--s2); margin-top: var(--s3); }
.fisc-note { padding: var(--s3); border-radius: var(--r2); font-size: 12px; line-height: 1.5; border: 1px solid var(--border-light); }
.fisc-note--ok    { background: var(--success-soft); border-color: #c8eecf; color: #1B5E20; }
.fisc-note--warn  { background: var(--warning-soft); border-color: #ffe0b2; color: #8B4500; }
.fisc-note--info  { background: var(--primary-soft); border-color: #c5dffc; color: #0A4DA2; }
.fisc-mito { background: linear-gradient(135deg, #fafafe 0%, #f3f0ff 100%); border-color: #d8cffa; }
.fisc-mito-table tbody tr:nth-child(1) td { background: var(--danger-soft); }
.fisc-mito-table tbody tr:nth-child(2) td { background: var(--success-soft); }
.fisc-mito-table tbody tr:nth-child(3) td { background: var(--warning-soft); }
.fisc-mito-takeaway { margin-top: var(--s4); padding: var(--s4); background: var(--card); border-radius: var(--r2); border-left: 4px solid var(--purple); font-size: 14px; line-height: 1.6; }

/* M4 — Accantonamento dinamico */
.fisc-accant-card { border-color: #f0c040; }
.fisc-accant-header { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: var(--s3); gap: var(--s3); }
.fisc-accant-chart-wrap { height: 240px; margin: var(--s3) 0 var(--s4); position: relative; }
.fisc-accant-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(135px, 1fr)); gap: var(--s2); margin-top: var(--s2); }
.fisc-accant-cell { padding: var(--s3); border: 1px solid var(--border-light); border-radius: var(--r2); background: var(--card); display: flex; flex-direction: column; gap: 4px; transition: all .15s; }
.fisc-accant-mese { font-size: 12px; font-weight: 700; color: var(--text-2); text-transform: uppercase; letter-spacing: .4px; }
.fisc-accant-target { font-size: 10px; color: var(--text-3); }
.fisc-accant-delta { font-size: 11px; font-weight: 600; text-align: right; }
.fisc-accant-cell--ok { background: var(--success-soft); border-color: #c8eecf; }
.fisc-accant-cell--ok .fisc-accant-delta { color: #1B5E20; }
.fisc-accant-cell--mancato { background: var(--danger-soft); border-color: #f5c6c2; }
.fisc-accant-cell--mancato .fisc-accant-delta { color: #C62828; }
.fisc-accant-cell--futuro .fisc-accant-delta { color: var(--text-3); }
.fisc-accant-cell--current { box-shadow: 0 0 0 2px var(--primary); }

/* M5 — Comparatore regimi */
.fisc-comparatore { background: linear-gradient(135deg, #ffffff 0%, #f0f7ff 100%); border-color: #c5dffc; }
.fisc-comp-cards { display: grid; grid-template-columns: 1fr 1fr; gap: var(--s4); margin: var(--s3) 0 var(--s4); }
@media (max-width: 820px) { .fisc-comp-cards { grid-template-columns: 1fr; } }
.fisc-comp-card { padding: var(--s4); border: 2px solid var(--border-light); border-radius: var(--r3); background: var(--card); position: relative; transition: all .2s; }
.fisc-comp-card--winner { border-color: var(--success); box-shadow: 0 4px 16px rgba(52,199,89,.18); }
.fisc-comp-card--blocked { opacity: 0.55; border-style: dashed; border-color: var(--danger); }
.fisc-comp-card-header { display: flex; align-items: center; gap: var(--s2); margin-bottom: var(--s3); padding-bottom: var(--s2); border-bottom: 1px solid var(--border-light); flex-wrap: wrap; }
.fisc-comp-card-title { font-size: 16px; font-weight: 700; color: var(--text); }
.fisc-comp-winner { margin-left: auto; padding: 3px 10px; border-radius: 999px; background: var(--success); color: white; font-size: 11px; font-weight: 700; }
.fisc-comp-rows { display: flex; flex-direction: column; gap: 6px; }
.fisc-comp-row { display: flex; justify-content: space-between; padding: 6px 0; font-size: 13px; border-bottom: 1px dashed var(--border-light); }
.fisc-comp-row:last-child { border-bottom: 0; }
.fisc-comp-row span { color: var(--text-2); }
.fisc-comp-row b { color: var(--text); font-variant-numeric: tabular-nums; }
.fisc-comp-row--accent { background: var(--gray-soft); padding: 8px var(--s2); border-radius: var(--r1); margin: 4px 0; }
.fisc-comp-row--accent span, .fisc-comp-row--accent b { color: var(--text); font-weight: 600; }
.fisc-comp-row--net { font-size: 15px; padding-top: 8px; }
.fisc-comp-row--net b { font-size: 18px; color: #1B5E20; font-weight: 800; }
.fisc-comp-verdict { display: flex; align-items: center; gap: var(--s3); padding: var(--s4); background: var(--purple-soft); border-radius: var(--r2); border-left: 4px solid var(--purple); margin-top: var(--s3); }
.fisc-comp-verdict-icon { font-size: 28px; flex-shrink: 0; color: var(--purple); font-weight: 700; }
.fisc-comp-verdict-title { font-size: 15px; font-weight: 700; color: var(--text); margin-bottom: 4px; }
.fisc-comp-verdict-text { font-size: 13px; color: var(--text-2); line-height: 1.6; }

/* M7 — Scadenzario calendario */
.cal-scad-banner { background: linear-gradient(135deg, #fff8e1 0%, #ffecb3 100%); border: 1px solid #f0c040; border-radius: var(--r3); padding: var(--s3) var(--s4); margin-bottom: var(--s3); }
.cal-scad-banner-title { font-size: 12px; font-weight: 700; color: #8d6e00; text-transform: uppercase; letter-spacing: .5px; margin-bottom: var(--s2); }
.cal-scad-banner-list { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: var(--s2); }
.cal-scad-item { display: grid; grid-template-columns: auto 1fr auto; gap: var(--s2); align-items: center; padding: 8px 12px; background: var(--card); border-radius: var(--r2); border-left: 3px solid var(--primary); font-size: 12px; }
.cal-scad-date { font-weight: 700; color: var(--text); white-space: nowrap; }
.cal-scad-title { color: var(--text-2); }
.cal-scad-urg { padding: 2px 8px; border-radius: 999px; background: var(--gray-soft); font-size: 10px; font-weight: 700; white-space: nowrap; }
.cal-scad-item--urgent { border-left-color: var(--danger); }
.cal-scad-item--urgent .cal-scad-urg { background: var(--danger-soft); color: #C62828; }
.cal-scad-item--soon   { border-left-color: var(--warning); }
.cal-scad-item--soon .cal-scad-urg { background: var(--warning-soft); color: #B25E00; }
.cal-scad-item--far    { border-left-color: var(--primary); }
.cal-scad-item--enpap  { border-left-color: var(--purple); }
.cal-scad-item--irpef  { border-left-color: var(--primary); }
.cal-scad-item--sts    { border-left-color: var(--success); }
.cal-cell--scadenza { background: linear-gradient(180deg, #fff8e1 0%, #ffffff 30%); }
.cell-scad-dot { margin-left: 4px; font-size: 10px; vertical-align: super; }
.cell-scad { margin-top: 4px; padding: 2px 6px; background: #fff8e1; color: #8d6e00; border-radius: 4px; font-size: 10px; font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.dp-scadenza { display: flex; gap: var(--s3); align-items: center; padding: var(--s3) var(--s4); background: linear-gradient(135deg, #fff8e1 0%, #ffecb3 100%); border: 1px solid #f0c040; border-radius: var(--r2); margin-bottom: var(--s4); }
.dp-scadenza-icon { font-size: 24px; flex-shrink: 0; }
.dp-scadenza-title { font-size: 11px; font-weight: 700; color: #8d6e00; text-transform: uppercase; letter-spacing: .4px; }
.dp-scadenza-text { font-size: 14px; font-weight: 600; color: #5d4900; margin-top: 2px; }
@media (max-width: 720px) { .fisc-hero { flex-direction: column; } .fisc-spesa-row { grid-template-columns: 1fr; } .fisc-kpi-value { font-size: 22px; } .fisc-breakdown { font-size: 12px; } }

/* ═══════════════════════════════════════════════════════════
   M8 — Dati per fattura nel form paziente
   ═══════════════════════════════════════════════════════════ */
.np-fiscale-section {
  margin: var(--s3) 0;
  border: 1px solid var(--border);
  border-radius: var(--r2);
  background: var(--gray-soft);
}
.np-fiscale-summary {
  padding: 10px 14px;
  font-size: 13px;
  font-weight: 600;
  color: var(--text);
  cursor: pointer;
  list-style: none;
  display: flex;
  align-items: center;
  gap: var(--s2);
  user-select: none;
}
.np-fiscale-summary::-webkit-details-marker { display: none; }
.np-fiscale-summary::before {
  content: '▸';
  font-size: 11px;
  color: var(--text-2);
  transition: transform .15s;
}
details[open] > .np-fiscale-summary::before { transform: rotate(90deg); }
.np-fiscale-hint { font-weight: 400; color: var(--text-2); font-size: 12px; }
.np-fiscale-body {
  padding: 0 14px 14px;
  display: flex;
  flex-direction: column;
  gap: var(--s3);
  border-top: 1px solid var(--border);
}

.np-cf-feedback {
  font-size: 11px;
  margin-top: 4px;
  min-height: 14px;
}
.np-cf-feedback--ok  { color: var(--success); font-weight: 600; }
.np-cf-feedback--err { color: var(--danger); font-weight: 600; }

.np-checkbox-row {
  display: flex;
  align-items: flex-start;
  gap: var(--s2);
  padding: 8px 0;
  cursor: pointer;
  font-size: 13px;
  line-height: 1.5;
}
.np-checkbox-row input[type="checkbox"] {
  margin-top: 2px;
  width: 16px;
  height: 16px;
  accent-color: var(--primary);
  flex-shrink: 0;
  cursor: pointer;
}
.np-checkbox-row small { color: var(--text-2); font-size: 11px; }

/* ═══════════════════════════════════════════════════════════
   F1 — Profilo professionista in Impostazioni
   ═══════════════════════════════════════════════════════════ */
.settings-card--wide { grid-column: 1 / -1; }
.settings-card-hint { font-weight: 400; color: var(--text-2); font-size: 12px; }
.settings-card-sub  { font-size: 12px; color: var(--text-2); margin: -8px 0 var(--s3); }

.prof-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: var(--s3);
}
.prof-row {
  display: flex; flex-direction: column; gap: 4px;
}
.prof-row--w1 { grid-column: span 2; }
.prof-row--w2 { grid-column: span 3; }
@media (max-width: 820px) {
  .prof-grid { grid-template-columns: 1fr; }
  .prof-row--w1, .prof-row--w2 { grid-column: span 1; }
}

/* ═══════════════════════════════════════════════════════════
   M8 — Sezione fattura nella scheda paziente esistente
   ═══════════════════════════════════════════════════════════ */
.pp-fiscale-section { padding: 0; }
.pp-fiscale-summary {
  cursor: pointer;
  padding: var(--s3) var(--s4);
  list-style: none;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--s2);
  user-select: none;
  border-bottom: 1px solid var(--border-light);
}
.pp-fiscale-summary::-webkit-details-marker { display: none; }
.pp-fiscale-summary::before {
  content: '▸';
  font-size: 11px;
  color: var(--text-2);
  margin-right: 6px;
  transition: transform .15s;
}
details[open] > .pp-fiscale-summary::before { transform: rotate(90deg); }
.pp-fiscale-status { margin-left: auto; }
.pp-fiscale-body {
  padding: var(--s4);
  display: flex;
  flex-direction: column;
  gap: var(--s3);
}
.pp-field-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: var(--s3); }
.pp-field-grid-3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: var(--s3); }
@media (max-width: 600px) {
  .pp-field-grid-2, .pp-field-grid-3 { grid-template-columns: 1fr; }
}

/* ═══════════════════════════════════════════════════════════
   F4 — Sezionali fattura nelle Impostazioni
   ═══════════════════════════════════════════════════════════ */
.sez-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: var(--s3);
  margin-top: var(--s3);
}
.sez-card {
  border: 1px solid var(--border);
  border-radius: var(--r2);
  background: var(--card);
  padding: var(--s3);
  display: flex;
  flex-direction: column;
  gap: var(--s2);
}
.sez-card-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.sez-prefisso {
  font-weight: 700;
  font-size: 16px;
  color: var(--primary);
}
.sez-stato {
  font-size: 11px;
  font-weight: 600;
  color: var(--text-2);
  text-transform: uppercase;
  letter-spacing: .4px;
}
.sez-counter-row {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.sez-input {
  text-align: right;
  font-variant-numeric: tabular-nums;
  font-weight: 600;
}
.sez-preview {
  font-size: 11px;
  color: var(--text-2);
  border-top: 1px dashed var(--border-light);
  padding-top: var(--s2);
}
.sez-preview b {
  color: var(--text);
  font-variant-numeric: tabular-nums;
}

/* ═══════════════════════════════════════════════════════════
   F1c — Modal "Emetti fattura"
   ═══════════════════════════════════════════════════════════ */
.fatt-modal { display: flex; flex-direction: column; gap: var(--s3); }
.fatt-warn {
  padding: var(--s3);
  background: var(--warning-soft);
  border: 1px solid #f0c040;
  border-left: 4px solid var(--warning);
  border-radius: var(--r2);
  font-size: 12px;
  color: #8B4500;
  line-height: 1.5;
}
.fatt-meta-row {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: var(--s3);
}
@media (max-width: 600px) { .fatt-meta-row { grid-template-columns: 1fr; } }

.fatt-num-preview {
  padding: 9px 12px;
  border: 1.5px solid var(--border);
  border-radius: var(--r2);
  background: var(--gray-soft);
  font-weight: 700;
  font-size: 14px;
  color: var(--primary);
  font-variant-numeric: tabular-nums;
}

.fatt-section-title {
  font-size: 13px;
  font-weight: 700;
  color: var(--text);
  text-transform: uppercase;
  letter-spacing: .4px;
  margin-top: var(--s3);
}

.fatt-sessions-list {
  display: flex;
  flex-direction: column;
  gap: 4px;
  max-height: 240px;
  overflow-y: auto;
  border: 1px solid var(--border);
  border-radius: var(--r2);
  padding: var(--s2);
}
.fatt-session-row {
  display: grid;
  grid-template-columns: auto 1fr 1.2fr auto auto;
  gap: var(--s3);
  align-items: center;
  padding: 8px 10px;
  border-radius: var(--r1);
  cursor: pointer;
  transition: background .15s;
}
.fatt-session-row:hover { background: var(--gray-soft); }
.fatt-session-row--unpaid { background: rgba(255, 196, 0, 0.06); }
.fatt-session-row--unpaid:hover { background: rgba(255, 196, 0, 0.12); }
.fatt-session-row input[type="checkbox"] {
  width: 16px; height: 16px; accent-color: var(--primary); cursor: pointer;
}
.fatt-session-date { font-weight: 600; font-size: 13px; }
.fatt-session-luogo { font-size: 12px; }
.fatt-session-importo { font-weight: 700; font-variant-numeric: tabular-nums; }
.fatt-session-paid-badge { font-size: 11px; color: #2a8a3a; font-weight: 600; white-space: nowrap; }
.fatt-session-unpaid-badge { font-size: 11px; color: #b8780f; font-weight: 600; white-space: nowrap; }

/* R1: indicatore "incassi riassegnati per competenza" (UB/ASL pagamento sfasato) */
.r1-sfaso-tag { display:inline-block; font-size:11px; color:#5856D6; background:rgba(88,86,214,.12); border-radius:4px; padding:0 4px; margin-left:2px; cursor:help; vertical-align:middle; }

/* ═══ Gestione Fatture (Cash Flow → Fatture) ═══ */
.gf-card { background:#fff; border:1px solid var(--border); border-radius:var(--r3); padding:var(--s4); }
.gf-header { display:flex; justify-content:space-between; align-items:flex-start; margin-bottom:var(--s3); }
.gf-header h3 { margin:0 0 4px; font-size:18px; }
.gf-sub { color:var(--text-2); font-size:13px; margin:0; }
.gf-filters { display:grid; grid-template-columns: 110px 1fr 1fr 2fr; gap:var(--s2); margin-bottom:var(--s3); }
@media (max-width:720px) { .gf-filters { grid-template-columns: 1fr 1fr; } }
.gf-search { width:100%; }
.gf-empty { padding:var(--s5); text-align:center; color:var(--text-2); background:var(--gray-soft); border-radius:var(--r2); }
.gf-table-wrap { overflow-x:auto; }
.gf-table { width:100%; border-collapse:collapse; font-size:13px; }
.gf-table th, .gf-table td { text-align:left; padding:8px 10px; border-bottom:1px solid var(--border); vertical-align:middle; }
.gf-table thead th { background:var(--gray-soft); font-weight:600; color:var(--text-2); font-size:12px; text-transform:uppercase; letter-spacing:.3px; }
.gf-num { text-align:right; font-variant-numeric:tabular-nums; white-space:nowrap; }
.gf-actions-col { white-space:nowrap; text-align:right; }
.gf-btn-icon { padding:4px 8px; font-size:14px; cursor:pointer; }
.gf-btn-danger:hover { color:#FF3B30; }
.gf-status { display:inline-block; padding:3px 8px; border-radius:12px; font-size:11px; font-weight:600; white-space:nowrap; }
.gf-st-paid { background:rgba(52,199,89,.16); color:#1f7a30; }
.gf-st-pending { background:rgba(255,196,0,.18); color:#8a6500; }
.gf-st-late { background:rgba(255,59,48,.14); color:#a8281a; }
.gf-st-void { background:#eee; color:#888; text-decoration:line-through; }
.gf-origin { display:inline-block; font-size:11px; padding:2px 6px; border-radius:4px; }
.gf-origin--imp { background:rgba(88,86,214,.12); color:#5856D6; }
.gf-origin--emit { background:rgba(0,122,255,.10); color:#007AFF; }
.gf-orphan-tag { display:inline-block; font-size:10px; padding:1px 5px; border-radius:3px; background:rgba(255,196,0,.18); color:#8a6500; margin-left:4px; }

.fatt-empty {
  padding: var(--s5);
  text-align: center;
  color: var(--text-2);
  background: var(--gray-soft);
  border-radius: var(--r2);
  font-size: 13px;
}

.fatt-preview-card {
  background: linear-gradient(135deg, #f0f7ff 0%, #ffffff 100%);
  border: 1px solid #c5dffc;
  border-radius: var(--r2);
  padding: var(--s3) var(--s4);
  margin-top: var(--s2);
}
.fatt-preview-title {
  font-size: 11px;
  font-weight: 700;
  color: var(--primary);
  text-transform: uppercase;
  letter-spacing: .4px;
  margin-bottom: var(--s2);
}
.fatt-preview-row {
  display: flex;
  justify-content: space-between;
  padding: 4px 0;
  font-size: 13px;
  border-bottom: 1px dashed var(--border-light);
}
.fatt-preview-row:last-child { border-bottom: 0; }
.fatt-preview-tot {
  margin-top: var(--s2);
  padding-top: var(--s2);
  border-top: 2px solid var(--primary);
  border-bottom: 0;
  font-size: 15px;
}
.fatt-preview-tot b { font-size: 17px; color: var(--primary); }

.fatt-actions {
  display: flex;
  justify-content: flex-end;
  gap: var(--s2);
  margin-top: var(--s3);
  padding-top: var(--s3);
  border-top: 1px solid var(--border-light);
  flex-wrap: wrap;
}
.fatt-actions button:disabled {
  opacity: 0.4;
  cursor: not-allowed;
}

/* ═══════════════════════════════════════════════════════════
   C1 — Checklist adempimenti fiscali
   ═══════════════════════════════════════════════════════════ */
.fisc-checklist-card {
  background: linear-gradient(135deg, #ffffff 0%, #fff8e1 100%);
  border-color: #f0c040;
}
.fisc-checklist-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: var(--s4);
  margin-bottom: var(--s4);
  flex-wrap: wrap;
}
.fisc-checklist-progress {
  display: flex;
  flex-direction: column;
  gap: 6px;
  min-width: 200px;
}
.fisc-checklist-progress-bar {
  height: 8px;
  background: var(--gray-soft);
  border-radius: 4px;
  overflow: hidden;
}
.fisc-checklist-progress-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--success), #4caf50);
  border-radius: 4px;
  transition: width .3s ease;
}
.fisc-checklist-progress-label {
  font-size: 12px;
  color: var(--text-2);
  text-align: right;
}
.fisc-checklist-progress-label b {
  color: var(--success);
  font-size: 14px;
}

.fisc-checklist-list {
  display: flex;
  flex-direction: column;
  gap: var(--s2);
}
.fisc-check-row {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: var(--s3);
  align-items: center;
  padding: var(--s3) var(--s4);
  background: var(--card);
  border: 1px solid var(--border-light);
  border-left: 4px solid var(--gray);
  border-radius: var(--r2);
  transition: all .15s;
}
.fisc-check-row--fatto { opacity: 0.55; border-left-color: var(--success); }
.fisc-check-row--fatto .fisc-check-title { text-decoration: line-through; color: var(--text-2); }
.fisc-check-row--scaduto { border-left-color: var(--danger); background: var(--danger-soft); }
.fisc-check-row--urgent  { border-left-color: var(--danger); background: linear-gradient(90deg, var(--danger-soft) 0%, var(--card) 30%); }
.fisc-check-row--soon    { border-left-color: var(--warning); }
.fisc-check-row--far     { border-left-color: var(--primary); }

.fisc-check-toggle {
  display: flex;
  align-items: center;
  cursor: pointer;
}
.fisc-check-toggle input[type="checkbox"] {
  appearance: none;
  width: 22px;
  height: 22px;
  border: 2px solid var(--border);
  border-radius: var(--r1);
  cursor: pointer;
  position: relative;
  transition: all .15s;
}
.fisc-check-toggle input[type="checkbox"]:checked {
  background: var(--success);
  border-color: var(--success);
}
.fisc-check-toggle input[type="checkbox"]:checked::after {
  content: '✓';
  color: white;
  font-size: 16px;
  font-weight: 700;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.fisc-check-body {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
}
.fisc-check-title {
  font-size: 14px;
  font-weight: 600;
  color: var(--text);
}
.fisc-check-meta {
  display: flex;
  gap: var(--s3);
  font-size: 11px;
  color: var(--text-2);
  flex-wrap: wrap;
}
.fisc-check-date { font-weight: 600; }

.fisc-check-urg {
  padding: 1px 8px;
  border-radius: 999px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .3px;
}
.fisc-check-urg--scaduto { background: var(--danger-soft); color: #C62828; }
.fisc-check-urg--urgent  { background: var(--danger-soft); color: #C62828; }
.fisc-check-urg--soon    { background: var(--warning-soft); color: #B25E00; }
.fisc-check-urg--far     { background: var(--gray-soft); color: var(--text-2); }
.fisc-check-urg--fatto   { background: var(--success-soft); color: #1B5E20; }

.fisc-check-tipo {
  padding: 1px 6px;
  border-radius: 4px;
  font-weight: 700;
  font-size: 10px;
}
.fisc-check-tipo--irpef { background: var(--primary-soft); color: #0A4DA2; }
.fisc-check-tipo--enpap { background: var(--purple-soft); color: #4527A0; }
.fisc-check-tipo--sts   { background: var(--success-soft); color: #1B5E20; }

.fisc-check-amount {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 110px;
}
.fisc-check-amount-label {
  font-size: 10px;
  color: var(--text-3);
  text-transform: uppercase;
  letter-spacing: .4px;
}
.fisc-input--small {
  font-size: 13px;
  padding: 5px 10px 5px 24px;
}

@media (max-width: 640px) {
  .fisc-check-row {
    grid-template-columns: auto 1fr;
    grid-template-rows: auto auto;
  }
  .fisc-check-amount {
    grid-column: 1 / -1;
    margin-top: var(--s2);
  }
}

/* ═══════════════════════════════════════════════════════════
   I1 — Importer fatture
   ═══════════════════════════════════════════════════════════ */
.imp-modal { display: flex; flex-direction: column; gap: var(--s3); }
.imp-formats { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: var(--s2); margin-bottom: var(--s3); }
.imp-format-badge {
  padding: var(--s3); background: var(--gray-soft); border-radius: var(--r2);
  font-size: 12px; line-height: 1.5;
}
.imp-format-badge b { color: var(--text); display: block; margin-bottom: 4px; }
.imp-format-badge span { color: var(--text-2); }

.imp-upload-zone {
  border: 2px dashed var(--border);
  border-radius: var(--r3);
  padding: var(--s6) var(--s4);
  text-align: center;
  background: var(--card);
  transition: all .15s;
}
.imp-upload-zone.dragover { border-color: var(--primary); background: var(--primary-soft); }

.imp-preview-card {
  margin-top: var(--s4); padding: var(--s4);
  background: var(--gray-soft); border-radius: var(--r2);
}
.imp-preview-header { display: flex; justify-content: space-between; align-items: center; gap: var(--s3); flex-wrap: wrap; }

.imp-map-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: var(--s3); margin-bottom: var(--s4);
}
.imp-map-row { display: flex; flex-direction: column; gap: 4px; }
.imp-map-row label { font-size: 12px; font-weight: 600; color: var(--text-2); }
.imp-map-row label .req { color: var(--danger); }

.imp-preview-table-wrap { max-height: 280px; overflow: auto; border: 1px solid var(--border); border-radius: var(--r2); background: var(--card); }
.imp-preview-table { width: 100%; border-collapse: collapse; font-size: 11px; }
.imp-preview-table th, .imp-preview-table td { padding: 6px 8px; text-align: left; border-bottom: 1px solid var(--border-light); white-space: nowrap; }
.imp-preview-table thead th { background: var(--gray-soft); position: sticky; top: 0; font-weight: 600; }

.imp-actions {
  display: flex; justify-content: flex-end; gap: var(--s2);
  margin-top: var(--s4); padding-top: var(--s3);
  border-top: 1px solid var(--border-light);
}

/* ═══════════════════════════════════════════════════════════
   R1 — Centro di riconciliazione 3-way (in Cash Flow)
   ═══════════════════════════════════════════════════════════ */
.r1-card {
  background: linear-gradient(135deg, #ffffff 0%, #f5faff 100%);
  border: 1px solid #c5dffc;
  border-radius: var(--r3);
  padding: var(--s5);
  margin-bottom: var(--s4);
  box-shadow: var(--shadow-xs);
}
.r1-header { display: flex; justify-content: space-between; align-items: flex-start; gap: var(--s4); margin-bottom: var(--s4); flex-wrap: wrap; }
.r1-header h3 { margin: 0 0 4px; font-size: 16px; font-weight: 700; }
.r1-sub { font-size: 12px; color: var(--text-2); margin: 0; }
.r1-alert-badge { background: var(--danger-soft); color: #C62828; padding: 6px 14px; border-radius: 999px; font-size: 12px; font-weight: 700; }
.r1-ok-badge { background: var(--success-soft); color: #1B5E20; padding: 6px 14px; border-radius: 999px; font-size: 12px; font-weight: 700; }

.r1-totals {
  display: grid;
  grid-template-columns: 1fr auto 1fr auto 1fr;
  gap: var(--s3);
  align-items: center;
  margin: var(--s4) 0;
}
@media (max-width: 820px) {
  .r1-totals { grid-template-columns: 1fr; }
  .r1-tot-arrow { display: none; }
}
.r1-tot-card { padding: var(--s4); border-radius: var(--r3); border: 1px solid transparent; }
.r1-tot-card--atteso    { background: var(--primary-soft); border-color: #c5dffc; }
.r1-tot-card--emesso    { background: var(--warning-soft); border-color: #ffe0b2; }
.r1-tot-card--incassato { background: var(--success-soft); border-color: #c8eecf; }
.r1-tot-label { font-size: 11px; font-weight: 600; color: var(--text-2); text-transform: uppercase; letter-spacing: .4px; }
.r1-tot-value { font-size: 24px; font-weight: 800; color: var(--text); margin: 4px 0; }
.r1-tot-sub { font-size: 11px; color: var(--text-2); }
.r1-tot-arrow { font-size: 24px; color: var(--text-3); text-align: center; }

.r1-h4 { margin: var(--s4) 0 var(--s2); font-size: 13px; font-weight: 600; color: var(--text-2); text-transform: uppercase; letter-spacing: .4px; }
.r1-table-wrap { overflow-x: auto; }
.r1-table { width: 100%; border-collapse: collapse; font-size: 13px; background: var(--card); border-radius: var(--r2); overflow: hidden; }
.r1-table th, .r1-table td { padding: 10px 12px; text-align: left; border-bottom: 1px solid var(--border-light); }
.r1-table thead th { background: var(--gray-soft); font-size: 11px; text-transform: uppercase; letter-spacing: .4px; color: var(--text-2); font-weight: 600; }
.r1-table tfoot th { background: #fafafc; font-weight: 700; color: var(--text); border-top: 2px solid var(--border); }
.r1-num { text-align: right !important; font-variant-numeric: tabular-nums; }
.r1-neg { color: var(--danger); font-weight: 600; }
.r1-row--alert { background: rgba(255, 149, 0, 0.05); }
.r1-alert-pill { background: var(--warning-soft); color: #B25E00; padding: 2px 8px; border-radius: 999px; font-size: 11px; font-weight: 600; }
.r1-ok-pill { color: var(--success); font-size: 14px; }

/* ═══════════════════════════════════════════════════════════
   K1 — Calcolatori avanzati
   ═══════════════════════════════════════════════════════════ */
.k1-card { background: linear-gradient(135deg, #ffffff 0%, #fef4ff 100%); border-color: #e0c5fc; }
.k1-tabs {
  display: flex; gap: var(--s2); flex-wrap: wrap;
  margin-bottom: var(--s4);
  border-bottom: 1px solid var(--border-light);
  padding-bottom: var(--s2);
}
.k1-tab {
  padding: 8px 14px; border: 1px solid var(--border);
  background: var(--card); border-radius: var(--r2);
  font-size: 12px; font-weight: 600; color: var(--text-2);
  cursor: pointer; transition: all .15s;
}
.k1-tab:hover { background: var(--gray-soft); color: var(--text); }
.k1-tab.active { background: var(--purple); color: white; border-color: var(--purple); }

.k1-content { padding-top: var(--s3); }
.k1-input-row { display: flex; flex-direction: column; gap: var(--s2); margin-bottom: var(--s3); }
.k1-input-row label { font-size: 12px; font-weight: 600; color: var(--text-2); }
.k1-pct-input { display: flex; align-items: center; gap: var(--s3); }
.k1-pct-display { font-size: 22px; font-weight: 800; color: var(--purple); min-width: 70px; text-align: right; font-variant-numeric: tabular-nums; }

.k1-breakeven-card {
  display: flex; flex-direction: column; gap: var(--s3);
  padding: var(--s4);
  background: var(--card); border-radius: var(--r2);
  border: 1px solid var(--border-light);
}
.k1-be-result { text-align: center; padding: var(--s4) 0; }
.k1-be-value { font-size: 32px; font-weight: 800; color: var(--purple); margin-bottom: 4px; }
.k1-be-label { font-size: 13px; color: var(--text-2); }
.k1-be-takeaway { font-size: 13px; line-height: 1.6; padding: var(--s3); background: var(--gray-soft); border-radius: var(--r2); }

/* ═══════════════════════════════════════════════════════════
   S1 — Smart suggestions banner
   ═══════════════════════════════════════════════════════════ */
.s1-banner {
  background: linear-gradient(135deg, #fff8e1 0%, #ffffff 100%);
  border: 1px solid #f0c040;
  border-radius: var(--r3);
  padding: var(--s3) var(--s4);
  margin-bottom: var(--s3);
}
.s1-banner-title { font-size: 12px; font-weight: 700; color: #8d6e00; text-transform: uppercase; letter-spacing: .5px; margin-bottom: var(--s2); }
.s1-banner-list { display: flex; flex-direction: column; gap: var(--s2); }
.s1-sug {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: var(--s3);
  align-items: center;
  padding: 10px 14px;
  background: var(--card);
  border-radius: var(--r2);
  border-left: 4px solid var(--gray);
}
.s1-sug--urgent { border-left-color: var(--danger); background: var(--danger-soft); }
.s1-sug--tax    { border-left-color: var(--danger); }
.s1-sug--warn   { border-left-color: var(--warning); }
.s1-sug--info   { border-left-color: var(--primary); }
.s1-sug-icon { font-size: 22px; }
.s1-sug-body { display: flex; flex-direction: column; gap: 2px; }
.s1-sug-title { font-size: 13px; font-weight: 700; color: var(--text); }
.s1-sug-text { font-size: 12px; color: var(--text-2); line-height: 1.5; }
.s1-sug-btn {
  padding: 6px 12px; background: var(--primary); color: white;
  border: none; border-radius: var(--r2);
  font-size: 12px; font-weight: 600; cursor: pointer;
  white-space: nowrap;
}
.s1-sug-btn:hover { background: #0066DD; }

@media (max-width: 600px) {
  .s1-sug { grid-template-columns: auto 1fr; grid-template-rows: auto auto; }
  .s1-sug-btn { grid-column: 1 / -1; margin-top: var(--s2); }
}

/* ═══════════════════════════════════════════════════════════
   F5 — Solleciti pagamento
   ═══════════════════════════════════════════════════════════ */
.f5-modal { display: flex; flex-direction: column; gap: var(--s3); }
.f5-info {
  padding: var(--s3); background: var(--warning-soft); border-left: 4px solid var(--warning);
  border-radius: var(--r2); font-size: 13px; line-height: 1.5;
}
.f5-tono-row { display: flex; align-items: center; gap: var(--s3); }
.f5-tono-row label { font-size: 12px; font-weight: 600; color: var(--text-2); }
.f5-tono-tabs { display: flex; gap: var(--s2); }
.f5-tono-tab {
  padding: 6px 14px; border: 1px solid var(--border); background: var(--card);
  border-radius: var(--r2); font-size: 12px; font-weight: 600; color: var(--text-2);
  cursor: pointer; text-transform: capitalize; transition: all .15s;
}
.f5-tono-tab:hover { background: var(--gray-soft); }
.f5-tono-tab.active { background: var(--primary); color: white; border-color: var(--primary); }

.f5-textarea {
  font-family: ui-monospace, 'SF Mono', Menlo, Consolas, monospace;
  font-size: 13px; line-height: 1.5;
}
.f5-actions {
  display: flex; gap: var(--s2); justify-content: flex-end; flex-wrap: wrap;
  margin-top: var(--s3); padding-top: var(--s3); border-top: 1px solid var(--border-light);
}

.f5-widget {
  background: linear-gradient(135deg, #fff8e1 0%, #ffffff 100%);
  border: 1px solid #f0c040; border-radius: var(--r3);
  padding: var(--s4); margin-bottom: var(--s4);
}
.f5-widget--empty { display: flex; align-items: center; gap: var(--s3); padding: var(--s3) var(--s4);
  background: var(--success-soft); border-color: #c8eecf; color: #1B5E20; }
.f5-widget-header { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: var(--s3); gap: var(--s3); }
.f5-widget-list { display: flex; flex-direction: column; gap: var(--s2); }
.f5-widget-row {
  display: grid; grid-template-columns: 1fr auto auto;
  gap: var(--s3); align-items: center;
  padding: var(--s3); background: var(--card); border-radius: var(--r2);
  border-left: 4px solid var(--warning);
}
.f5-widget-name { font-weight: 600; font-size: 14px; color: var(--text); }
.f5-widget-amount { font-size: 18px; font-weight: 800; color: var(--danger); font-variant-numeric: tabular-nums; }

.f5-templates-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: var(--s3); margin-top: var(--s3);
}
.f5-template-card { padding: var(--s3); background: var(--gray-soft); border-radius: var(--r2); }
.f5-template-textarea { font-family: ui-monospace, 'SF Mono', Menlo, Consolas, monospace; font-size: 12px; }

.pp-pay-btn--bonus {
  background: var(--purple-soft) !important;
  color: var(--purple) !important;
  border: 1px solid var(--purple) !important;
  margin-left: 4px;
}

/* ═══════════════════════════════════════════════════════════
   F6 — Bonus Psicologo
   ═══════════════════════════════════════════════════════════ */
.pp-bonus-section { background: linear-gradient(135deg, #ffffff 0%, #eeeeff 100%); }

.f6-progress-row { display: flex; flex-direction: column; gap: var(--s2); margin-bottom: var(--s3); }
.f6-progress-bar {
  height: 10px; background: var(--gray-soft); border-radius: 5px; overflow: hidden;
}
.f6-progress-fill {
  height: 100%; background: linear-gradient(90deg, var(--purple), #7B5BE0);
  border-radius: 5px; transition: width .3s ease;
}
.f6-progress-label { font-size: 12px; color: var(--text-2); }
.f6-progress-label b { color: var(--text); }

.f6-info-box {
  margin-top: var(--s3); padding: var(--s3);
  background: var(--primary-soft); border-radius: var(--r2);
  font-size: 12px; line-height: 1.5; color: #0A4DA2;
}
.f6-alert {
  margin-top: var(--s3); padding: var(--s3);
  background: var(--warning-soft); border-left: 3px solid var(--warning);
  border-radius: var(--r2); font-size: 13px; color: #8B4500; font-weight: 600;
}

.f6-widget {
  background: linear-gradient(135deg, #eeeeff 0%, #ffffff 100%);
  border: 1px solid #d8cffa; border-radius: var(--r3);
  padding: var(--s4); margin-bottom: var(--s4);
}
.f6-widget-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: var(--s3); gap: var(--s3); flex-wrap: wrap; }
.f6-widget-list { display: flex; flex-direction: column; gap: var(--s2); }
.f6-widget-row {
  display: grid; grid-template-columns: 1.2fr 1.4fr auto;
  gap: var(--s3); align-items: center;
  padding: var(--s3); background: var(--card); border-radius: var(--r2);
  border-left: 4px solid var(--purple);
  cursor: pointer; transition: all .15s;
}
.f6-widget-row:hover { transform: translateX(2px); box-shadow: var(--shadow-sm); }
.f6-widget-row--alert { border-left-color: var(--danger); background: var(--danger-soft); }
.f6-widget-name { font-weight: 600; font-size: 14px; }
.f6-widget-code { font-family: ui-monospace, 'SF Mono', Menlo, Consolas, monospace; font-size: 11px; }
.f6-widget-bar-wrap { display: flex; flex-direction: column; gap: 2px; }
.f6-widget-residuo {
  text-align: right;
  display: flex; flex-direction: column; align-items: flex-end;
  font-variant-numeric: tabular-nums;
}
.f6-widget-residuo b { font-size: 16px; color: var(--purple); }

@media (max-width: 720px) {
  .f5-widget-row, .f6-widget-row { grid-template-columns: 1fr; }
}

/* ═══════════════════════════════════════════════════════════
   Account / Login / Sync / Subscription
   ═══════════════════════════════════════════════════════════ */
.acc-card { background: linear-gradient(135deg, #ffffff 0%, #f0f7ff 100%); border-color: #c5dffc; }

.acc-tabs { display: flex; gap: var(--s2); margin-bottom: var(--s3); border-bottom: 1px solid var(--border-light); padding-bottom: var(--s2); }
.acc-tab {
  padding: 8px 16px; border: 1px solid var(--border); background: var(--card);
  border-radius: var(--r2); font-size: 13px; font-weight: 600; color: var(--text-2);
  cursor: pointer; transition: all .15s;
}
.acc-tab.active { background: var(--primary); color: white; border-color: var(--primary); }

.acc-form { display: flex; flex-direction: column; gap: var(--s3); max-width: 420px; }
.acc-feedback { font-size: 13px; padding: 8px 12px; border-radius: var(--r2); min-height: 14px; }
.acc-feedback--info    { background: var(--primary-soft); color: #0A4DA2; }
.acc-feedback--success { background: var(--success-soft); color: #1B5E20; }
.acc-feedback--error   { background: var(--danger-soft); color: #C62828; }

.acc-user-row {
  display: flex; justify-content: space-between; align-items: center;
  padding: var(--s3); background: var(--card); border-radius: var(--r2);
  margin-bottom: var(--s4); border: 1px solid var(--border-light); flex-wrap: wrap; gap: var(--s2);
}
.acc-user-email { font-weight: 600; font-size: 15px; }
.acc-user-meta { display: flex; gap: var(--s2); align-items: center; margin-top: 4px; flex-wrap: wrap; }

.acc-actions-grid { display: flex; flex-direction: column; gap: var(--s2); }
.acc-action-row {
  display: flex; justify-content: space-between; align-items: center;
  padding: var(--s3); background: var(--card); border-radius: var(--r2);
  border: 1px solid var(--border-light); gap: var(--s3); flex-wrap: wrap;
}
.acc-action-title { font-weight: 600; font-size: 14px; }
.acc-action-sub { font-size: 12px; color: var(--text-2); margin-top: 2px; }

.acc-sub-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--s3); margin-top: var(--s2); }
@media (max-width: 720px) { .acc-sub-grid { grid-template-columns: 1fr; } }
.acc-sub-card {
  padding: var(--s4); background: var(--card); border: 2px solid var(--border);
  border-radius: var(--r3); position: relative;
}
.acc-sub-card--featured { border-color: var(--primary); box-shadow: 0 4px 16px rgba(0,122,255,.15); }
.acc-sub-card--active   { background: var(--success-soft); border-color: var(--success); }
.acc-sub-status { font-size: 16px; font-weight: 700; color: #1B5E20; margin-bottom: 4px; }
.acc-sub-badge {
  position: absolute; top: -8px; right: 12px;
  background: var(--success); color: white; font-size: 11px; font-weight: 700;
  padding: 2px 10px; border-radius: 999px;
}
.acc-sub-name { font-size: 12px; font-weight: 600; color: var(--text-2); text-transform: uppercase; letter-spacing: .4px; }
.acc-sub-price { font-size: 36px; font-weight: 800; color: var(--text); line-height: 1; margin: 4px 0; }
.acc-sub-price span { font-size: 14px; font-weight: 400; color: var(--text-2); }
.acc-sub-features { display: flex; flex-direction: column; gap: 4px; font-size: 13px; margin-top: var(--s3); }
.acc-sub-features div { color: var(--text-2); }

/* ═══════════════════════════════════════════════════════════
   Onboarding wizard (first-login modal)
   ═══════════════════════════════════════════════════════════ */
.ob-overlay {
  position: fixed; inset: 0; z-index: 10000;
  background: rgba(15, 23, 42, 0.55);
  backdrop-filter: blur(4px);
  display: flex; align-items: center; justify-content: center;
  padding: var(--s3);
  animation: ob-fade .25s ease-out;
}
@keyframes ob-fade { from { opacity: 0; } to { opacity: 1; } }

.ob-modal {
  background: var(--card); border-radius: var(--r4);
  width: 100%; max-width: 560px;
  max-height: 90vh; overflow: hidden;
  display: flex; flex-direction: column;
  box-shadow: 0 24px 64px rgba(0,0,0,.25);
  animation: ob-up .3s cubic-bezier(.16,1,.3,1);
}
@keyframes ob-up { from { transform: translateY(20px); opacity: 0; } to { transform: translateY(0); opacity: 1; } }

.ob-progress { height: 4px; background: var(--border-light); }
.ob-progress-bar {
  height: 100%; background: linear-gradient(90deg, var(--primary), var(--success));
  transition: width .3s ease;
}

.ob-body { padding: var(--s5) var(--s5) var(--s4); overflow-y: auto; }
.ob-title { font-size: 22px; font-weight: 700; margin: 0 0 6px; }
.ob-sub { color: var(--text-2); font-size: 14px; margin: 0 0 var(--s4); }
.ob-form { display: flex; flex-direction: column; gap: var(--s3); }
.ob-form .form-label { font-weight: 600; font-size: 13px; margin-bottom: 4px; display: block; }
.ob-form .form-input, .ob-form .form-select { width: 100%; }

.ob-tariffe-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--s3); }
@media (max-width: 540px) { .ob-tariffe-grid { grid-template-columns: 1fr; } }

/* Step 2 wizard: profilo professionista — griglia 2 colonne con alcune righe full-width */
.ob-prof-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--s3); max-height: 60vh; overflow-y: auto; padding-right: var(--s2); }
.ob-prof-grid .ob-fullw { grid-column: 1 / -1; }
@media (max-width: 540px) { .ob-prof-grid { grid-template-columns: 1fr; } }
.ob-input-suffix { position: relative; }
.ob-input-suffix input { padding-right: 80px; font-variant-numeric: tabular-nums; }
.ob-input-suffix span {
  position: absolute; right: 12px; top: 50%; transform: translateY(-50%);
  font-size: 12px; color: var(--text-2); pointer-events: none;
}

.ob-options { display: flex; flex-direction: column; gap: var(--s2); }
.ob-option {
  display: flex; gap: var(--s3); align-items: flex-start;
  padding: var(--s3); background: var(--card-soft, #f8fafc); border-radius: var(--r2);
  border: 1px solid var(--border-light);
}
.ob-option-icon { font-size: 28px; line-height: 1; }
.ob-option-text b { display: block; font-size: 14px; margin-bottom: 2px; }
.ob-option-text p { margin: 0; color: var(--text-2); font-size: 13px; }

.ob-actions {
  display: flex; justify-content: space-between; align-items: center;
  margin-top: var(--s4); gap: var(--s2); flex-wrap: wrap;
}
.ob-actions .btn-primary { min-width: 140px; }

/* ═══════════════════════════════════════════════════════════
   Auth Gate v2 — split layout SaaS-grade
   Layout: brand left (60%) + form right (40%) su desktop ≥ 880px.
   Stack su mobile.
   ═══════════════════════════════════════════════════════════ */
.auth-gate {
  position: fixed; inset: 0; z-index: 9999;
  background:
    radial-gradient(circle at 15% 0%,  rgba(0,122,255,0.10), transparent 45%),
    radial-gradient(circle at 90% 100%, rgba(52,199,89,0.10), transparent 45%),
    linear-gradient(135deg, #fbfdff 0%, #f0f6ff 100%);
  overflow-y: auto;
  animation: ag-fade .3s ease-out;
}
@keyframes ag-fade { from { opacity: 0; } to { opacity: 1; } }

.auth-gate-grid {
  min-height: 100vh;
  width: 100%;
  max-width: 1280px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1.15fr 1fr;
  gap: 48px;
  padding: 48px 48px;
  align-items: stretch;
  animation: ag-up .35s cubic-bezier(.16,1,.3,1);
}
@keyframes ag-up { from { transform: translateY(12px); opacity: 0; } to { transform: translateY(0); opacity: 1; } }

@media (max-width: 880px) {
  .auth-gate-grid {
    grid-template-columns: 1fr;
    gap: 32px;
    padding: 28px 20px;
  }
}

/* ── Lato brand ───────────────────────────────────────── */
.auth-gate-brand {
  display: flex; flex-direction: column;
  padding: 0;
  min-width: 0;
}

.auth-gate-brand-top {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 56px;
}
@media (max-width: 880px) {
  .auth-gate-brand-top { margin-bottom: 24px; }
}

.auth-gate-brand-logo {
  display: flex; align-items: center; gap: 12px;
}
.auth-gate-icon {
  width: 48px; height: 48px; border-radius: 11px;
  box-shadow: 0 4px 14px rgba(0,122,255,.22);
}
.auth-gate-brand-name {
  font-size: 19px; font-weight: 800; letter-spacing: -0.4px;
  color: var(--text);
}
/* Wordmark login page (logo opzione 1):
   "Tutto" in blu navy fisso, "Chiaro" con gradiente blu→verde scurito.
   #1FA86A è verde scurito apposta per leggibilità su sfondo bianco —
   NON usare #34C759 qui (l'icona usa #34C759 perché è su sfondo blu del badge). */
.auth-gate-brand-name .lg-tutto  { color:#1A3A5C; }
.auth-gate-brand-name .lg-chiaro {
  background:linear-gradient(90deg,#007AFF,#1FA86A);
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.auth-gate-brand-pill {
  font-size: 11px; font-weight: 600;
  color: var(--text-2);
  background: rgba(0,0,0,.04);
  padding: 4px 10px; border-radius: 999px;
}

.auth-gate-brand-hero { margin-bottom: 36px; }
.auth-gate-hero-title {
  font-size: 44px; line-height: 1.1; letter-spacing: -1px;
  font-weight: 800; color: var(--text);
  margin: 0 0 16px;
}
.auth-gate-hero-accent {
  background: linear-gradient(135deg, #007AFF 0%, #34C759 100%);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent;
  white-space: nowrap;
}
.auth-gate-hero-sub {
  font-size: 17px; line-height: 1.55;
  color: var(--text-2);
  margin: 0;
}
@media (max-width: 880px) {
  .auth-gate-hero-title { font-size: 28px; }
  .auth-gate-hero-sub { font-size: 15px; }
}

.auth-gate-bullets {
  list-style: none; padding: 0; margin: 0 0 36px;
  display: flex; flex-direction: column; gap: 18px;
}
.auth-gate-bullets li {
  display: flex; gap: 14px; align-items: flex-start;
}
.auth-gate-bullet-icon {
  font-size: 22px; line-height: 1.2;
  flex-shrink: 0;
  width: 32px; text-align: center;
}
.auth-gate-bullets b {
  display: block; font-size: 14px; font-weight: 600;
  color: var(--text); margin-bottom: 2px;
}
.auth-gate-bullets span:not(.auth-gate-bullet-icon) {
  font-size: 13px; color: var(--text-2); line-height: 1.5;
}

.auth-gate-trust {
  margin-top: auto;
  padding: 16px 18px;
  background: rgba(0,0,0,.025);
  border-radius: 10px;
  border-left: 3px solid #34C759;
}
.auth-gate-trust > span {
  display: block;
  color: #f5a623;
  letter-spacing: 2px;
  font-size: 14px;
  margin-bottom: 6px;
}
.auth-gate-trust p {
  margin: 0; font-size: 13px; line-height: 1.55;
  color: var(--text-2); font-style: italic;
}

/* ── Lato form ────────────────────────────────────────── */
.auth-gate-form-side {
  display: flex; flex-direction: column;
  justify-content: center;
  gap: 16px;
  min-width: 0;
}
.auth-gate-form-card {
  background: white; border-radius: 16px;
  padding: 36px 32px 28px;
  box-shadow:
    0 1px 3px rgba(0,0,0,.06),
    0 16px 48px rgba(0,40,120,.10);
}
.auth-gate-form-header { margin-bottom: 24px; }
.auth-gate-form-title {
  font-size: 26px; font-weight: 800;
  letter-spacing: -0.5px;
  color: var(--text);
  margin: 0 0 6px;
}
.auth-gate-form-sub {
  font-size: 14px; color: var(--text-2);
  margin: 0;
}

.auth-gate-tabs {
  display: flex; gap: 0;
  background: rgba(0,0,0,.04);
  padding: 4px; border-radius: 10px;
  margin-bottom: 24px;
  border: none !important;
}
.auth-gate-tabs .acc-tab {
  flex: 1;
  padding: 10px 16px;
  border: none !important;
  background: transparent;
  border-radius: 7px;
  font-size: 14px; font-weight: 600;
  color: var(--text-2);
  cursor: pointer;
  transition: all .18s;
}
.auth-gate-tabs .acc-tab.active {
  background: white;
  color: var(--text);
  box-shadow: 0 2px 6px rgba(0,0,0,.07);
}
.auth-gate-tabs .acc-tab:not(.active):hover {
  color: var(--text);
}

/* Stilizzo i form interni quando dentro all'auth gate */
.auth-gate-form-card .acc-form {
  max-width: none;
  gap: 16px;
}
.auth-gate-form-card .acc-form .form-input {
  font-size: 15px;
  padding: 12px 14px;
  border-radius: 9px;
}
.auth-gate-form-card .acc-form .form-label {
  font-size: 12px; font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--text-2);
  margin-bottom: 6px;
}
.auth-gate-form-card .acc-form .btn-primary {
  width: 100%;
  padding: 13px;
  font-size: 15px; font-weight: 600;
  border-radius: 9px;
  margin-top: 4px;
  box-shadow: 0 4px 12px rgba(0,122,255,.25);
}
.auth-gate-form-card .acc-form .btn-primary:hover {
  box-shadow: 0 6px 16px rgba(0,122,255,.32);
}
.auth-gate-form-card .acc-form .btn-secondary {
  width: 100%;
  padding: 11px;
  font-size: 13px;
  border-radius: 9px;
}
.auth-gate-form-card .acc-form > div[style*="display:flex"] {
  flex-direction: column !important;
  gap: 10px !important;
}
.auth-gate-form-card .acc-form .text-sm.text-2 {
  font-size: 12px; color: var(--text-2); line-height: 1.55;
}

.auth-gate-form-footer {
  text-align: center;
  margin-top: 18px;
  padding-top: 18px;
  border-top: 1px solid var(--border-light);
}
.auth-gate-form-footer small {
  font-size: 13px; color: var(--text-2);
}
.auth-gate-form-footer a {
  color: var(--primary); text-decoration: none; font-weight: 600;
  margin-left: 4px;
}
.auth-gate-form-footer a:hover { text-decoration: underline; }

.auth-gate-fineprint {
  text-align: center;
  font-size: 11px;
  color: var(--text-2);
  line-height: 1.6;
  margin: 0;
  padding: 0 12px;
}
.auth-gate-fineprint a {
  color: var(--primary); text-decoration: none;
}
.auth-gate-fineprint a:hover { text-decoration: underline; }

@media (max-width: 880px) {
  .auth-gate-form-card { padding: 28px 22px 22px; }
  .auth-gate-form-title { font-size: 22px; }
  .auth-gate-trust { display: none; }
}

/* ═══════════════════════════════════════════════════════════
   Sync Status badge (header) — indicatore stato cloud
   ═══════════════════════════════════════════════════════════ */
.sync-status {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 5px 11px;
  font-size: 12px; font-weight: 500;
  border-radius: 999px;
  border: 1px solid var(--border-light);
  background: var(--card);
  color: var(--text-2);
  margin-left: auto;
  cursor: default;
  user-select: none;
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}
.sync-status-dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--text-2);
  flex-shrink: 0;
}
.sync-status--idle    .sync-status-dot { background: #9aa0a6; }
.sync-status--pending .sync-status-dot { background: #f5a623; animation: sync-pulse 1.2s ease-in-out infinite; }
.sync-status--saving  .sync-status-dot { background: #007AFF; animation: sync-pulse .9s ease-in-out infinite; }
.sync-status--saved   .sync-status-dot { background: #34C759; }
.sync-status--offline .sync-status-dot { background: #ff9500; }
.sync-status--error   .sync-status-dot { background: #ff3b30; }

.sync-status--saved  { color: #1B5E20; border-color: rgba(52,199,89,.30); background: rgba(52,199,89,.06); }
.sync-status--saving { color: #0A4DA2; border-color: rgba(0,122,255,.30); background: rgba(0,122,255,.06); }
.sync-status--offline{ color: #b15c00; border-color: rgba(255,149,0,.30);  background: rgba(255,149,0,.06); }
.sync-status--error  { color: #c62828; border-color: rgba(255,59,48,.30);  background: rgba(255,59,48,.06); }

@keyframes sync-pulse {
  0%, 100% { opacity: 1; }
  50%      { opacity: .35; }
}

@media (max-width: 720px) {
  .sync-status .sync-status-label { display: none; }
  .sync-status { padding: 6px; }
}

/* ═══════════════════════════════════════════════════════════
   COMPACT DENSITY — ottimizzazioni per laptop 14"
   Target: schermi viewport ~1280×630. Funziona bene anche su FullHD/4K.
   Sostituisce/restringe padding+font/dimensioni di alcuni elementi chiave
   per ridurre l'overflow e massimizzare l'info visibile sopra la piega.
   ═══════════════════════════════════════════════════════════ */
:root {
  --header-h: 54px;
}

/* ── Header app-bar + logo più compatti ── */
.app-bar-inner { padding: 0 var(--s4); gap: var(--s4); }
.app-logo-img  { height: 32px; width: 32px; }
.app-logo-text { font-size: 15px; }

/* Tab nav compatto */
.tab-btn { padding: 5px 10px; font-size: 12.5px; gap: 6px; }
.tab-btn svg { width: 13px; height: 13px; }

/* Main: padding ridotti */
.app-main { padding: var(--s4) var(--s4); }

/* ── Calendar: cella più bassa, font densi, banner compatti ── */
.cal-toolbar { margin-bottom: var(--s3); gap: var(--s3); }
.cal-month-title { font-size: 18px; min-width: 170px; }
.nav-arrow { width: 30px; height: 30px; font-size: 16px; }

.cal-cell { min-height: 56px; padding: 5px 8px; }
.cal-cell--pad { min-height: 56px; }
.cal-cell--head { padding: 4px 8px; font-size: 10px; }
.cell-num { font-size: 12px; margin-bottom: 1px; }
.cell-rev { font-size: 13px; }
.wt { font-size: 11px; }
.cc { font-size: 9px; padding: 1px 4px; line-height: 1.35; }

.cal-month-summary {
  margin-top: var(--s3);
  padding: var(--s3) var(--s4);
  grid-template-columns: minmax(220px, 1fr) 1.6fr;
  gap: var(--s4);
}

/* ── S1 Suggestion banner: compatto 1 riga ── */
.s1-banner {
  padding: 6px 12px !important;
  margin-bottom: var(--s2) !important;
  display: flex;
  align-items: center;
  gap: var(--s3);
}
.s1-banner-title {
  font-size: 11px !important;
  margin-bottom: 0 !important;
  white-space: nowrap;
  flex-shrink: 0;
}
.s1-banner-list {
  flex: 1; min-width: 0;
  display: flex !important; flex-direction: row !important;
  gap: var(--s2) !important;
  overflow-x: auto;
}
.s1-sug {
  flex-shrink: 0;
  padding: 4px 10px !important;
  border-radius: 999px !important;
  border-left-width: 0 !important;
  border-left: 3px solid var(--primary) !important;
  background: rgba(255,255,255,0.7) !important;
  display: flex; align-items: center; gap: 6px;
  font-size: 12px;
}
.s1-sug-icon { font-size: 14px !important; }
.s1-sug-body { flex-direction: row !important; gap: 4px !important; align-items: baseline; }
.s1-sug-title { font-size: 12px !important; }
.s1-sug-text {
  font-size: 11px !important;
  color: var(--text-2);
  max-width: 280px;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.s1-sug-btn {
  padding: 3px 8px !important;
  font-size: 11px !important;
  margin-left: 4px;
}

/* ── Calendar deadlines banner: compatto 1 riga ── */
.cal-scad-banner {
  padding: 6px 12px !important;
  margin-bottom: var(--s2) !important;
  display: flex;
  align-items: center;
  gap: var(--s3);
}
.cal-scad-banner-title {
  font-size: 11px !important;
  margin-bottom: 0 !important;
  white-space: nowrap;
  flex-shrink: 0;
}
.cal-scad-banner-list {
  flex: 1; min-width: 0;
  display: flex !important;
  grid-template-columns: none !important;
  gap: var(--s2) !important;
  overflow-x: auto;
}
.cal-scad-item {
  flex-shrink: 0;
  padding: 3px 10px !important;
  font-size: 11px !important;
  background: rgba(255,255,255,0.7) !important;
}
.cal-scad-date { font-size: 11px; }
.cal-scad-urg { font-size: 10px !important; padding: 1px 6px !important; }

/* ═══ CALENDARIO PREMIUM v2 — Stripe/Linear style ═══════════
   Hero tile gigante con €totale + attention tile a destra.
   Niente più banner inquinanti, dopamina visiva centrata sul ricavo.
   ═══════════════════════════════════════════════════════════ */

/* HERO ROW — 2 tiles fianco a fianco */
.cal-hero-row {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 14px;
  margin-bottom: 14px;
}
@media (max-width: 880px) {
  .cal-hero-row { grid-template-columns: 1fr; }
}

/* KPI tile: €totale gigante con gradient */
.cal-hero-kpi {
  background: linear-gradient(135deg, #ffffff 0%, #f7fbff 100%);
  border: 1px solid rgba(0,0,0,0.06);
  border-radius: 14px;
  padding: 18px 22px 14px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 1px 3px rgba(0,0,0,0.04);
}
.cal-hero-kpi::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, #007AFF 0%, #34C759 50%, #FF9500 100%);
}
.cal-hero-label {
  font-size: 10px; font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--text-3);
}
.cal-hero-amount {
  font-size: 48px;
  font-weight: 900;
  letter-spacing: -2px;
  line-height: 1;
  margin-top: 6px;
  background: linear-gradient(135deg, #007AFF 0%, #34C759 50%, #FF9500 100%);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent;
  font-variant-numeric: tabular-nums;
}
.cal-hero-trend {
  margin-top: 4px;
  font-size: 12px; font-weight: 600;
  color: var(--text-2);
  font-variant-numeric: tabular-nums;
}
.cal-hero-trend--up   { color: #248a3e; }
.cal-hero-trend--down { color: #c62828; }

.cal-hero-chips {
  display: flex; flex-wrap: wrap;
  gap: 6px;
  margin-top: 10px;
}
.cal-hero-chips-empty {
  font-size: 12px; color: var(--text-3); font-style: italic;
}
.cal-hero-chip {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 4px 10px 4px 8px;
  background: rgba(0,0,0,0.04);
  border-radius: 999px;
  font-size: 11.5px;
  font-variant-numeric: tabular-nums;
}
.cal-hero-chip-dot {
  width: 7px; height: 7px;
  border-radius: 50%;
  flex-shrink: 0;
}
.cal-hero-chip-label {
  font-weight: 700;
  color: var(--text-2);
  letter-spacing: 0.2px;
}
.cal-hero-chip-amt {
  font-weight: 700;
  color: var(--text);
}

/* Attention tile: scadenza + alert raggruppati elegantemente */
.cal-hero-attention {
  background: white;
  border: 1px solid rgba(0,0,0,0.06);
  border-radius: 14px;
  padding: 8px;
  display: flex; flex-direction: column;
  gap: 6px;
  box-shadow: 0 1px 3px rgba(0,0,0,0.04);
}
.cal-hero-att-row {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 12px;
  border-radius: 10px;
  background: rgba(0,0,0,0.025);
  transition: background .15s;
}
.cal-hero-att-row:hover { background: rgba(0,0,0,0.04); }
.cal-hero-att-row--scad {
  background: linear-gradient(90deg, rgba(0,122,255,0.06), rgba(0,122,255,0.02));
  border-left: 3px solid var(--primary);
}
.cal-hero-att-row--scad.cal-hero-att-row--urgent { background: linear-gradient(90deg, rgba(255,59,48,0.08), rgba(255,59,48,0.02)); border-left-color: #ff3b30; }
.cal-hero-att-row--scad.cal-hero-att-row--soon   { background: linear-gradient(90deg, rgba(255,149,0,0.07), rgba(255,149,0,0.02)); border-left-color: #ff9500; }
.cal-hero-att-row--sug { background: rgba(255,200,0,0.06); border-left: 3px solid #f5a623; }
.cal-hero-att-row--sug.cal-hero-att-row--urgent { background: rgba(255,59,48,0.06); border-left-color: #ff3b30; }
.cal-hero-att-row--sug.cal-hero-att-row--warn   { background: rgba(255,149,0,0.06); border-left-color: #ff9500; }
.cal-hero-att-row--sug.cal-hero-att-row--info   { background: rgba(0,122,255,0.06); border-left-color: #007AFF; }

.cal-hero-att-icon {
  font-size: 18px;
  width: 26px; text-align: center;
  flex-shrink: 0;
}
.cal-hero-att-body {
  flex: 1; min-width: 0;
}
.cal-hero-att-meta {
  font-size: 10.5px;
  color: var(--text-2);
  margin-bottom: 1px;
  letter-spacing: 0.2px;
}
.cal-hero-att-meta b {
  color: var(--text);
  font-size: 12px;
  font-weight: 700;
}
.cal-hero-att-title {
  font-size: 12.5px;
  font-weight: 600;
  color: var(--text);
  line-height: 1.3;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.cal-hero-att-sub {
  font-size: 11px;
  color: var(--text-2);
  line-height: 1.3;
  margin-top: 2px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.cal-hero-att-action {
  flex-shrink: 0;
  background: white;
  border: 1px solid rgba(0,0,0,0.1);
  color: var(--primary);
  font-size: 11px; font-weight: 700;
  padding: 5px 10px;
  border-radius: 6px;
  cursor: pointer;
  transition: all .15s;
}
.cal-hero-att-action:hover {
  background: var(--primary);
  color: white;
  border-color: var(--primary);
}
.cal-hero-att-empty {
  display: flex; align-items: center; gap: 10px;
  padding: 14px 12px;
  background: rgba(52,199,89,0.05);
  border-radius: 10px;
  border-left: 3px solid #34C759;
}
.cal-hero-att-empty .cal-hero-att-icon { color: #34C759; font-weight: 800; }

/* ── Originale "restyle premium" — celle calendario ─────── */

/* Wrap: no scroll orizzontale, no min-width forzato */
.cal-wrap { overflow: visible !important; }
.cal-grid {
  min-width: 0 !important;
  border: 1px solid rgba(0,0,0,0.06) !important;
  border-radius: 12px !important;
  box-shadow: 0 1px 2px rgba(0,0,0,0.03) !important;
  background: var(--card);
}

/* Grid columns: settimana più stretta, celle fluide */
.cal-row {
  grid-template-columns: repeat(7, 1fr) 78px !important;
}

/* Bordo riga discreto */
.cal-row + .cal-row { border-top-color: rgba(0,0,0,0.05) !important; }

/* Bordo colonna ancora più discreto */
.cal-cell {
  min-height: 56px !important;
  padding: 5px 7px !important;
  border-right-color: rgba(0,0,0,0.05) !important;
}
.cal-cell--pad {
  min-height: 56px !important;
  background: transparent !important;
  opacity: 0.55;
}

/* Header giorni discreto, no background grigio aggressivo */
.cal-cell--head {
  background: transparent !important;
  font-size: 9.5px !important;
  font-weight: 600 !important;
  color: var(--text-3) !important;
  letter-spacing: 0.7px !important;
  padding: 7px 8px !important;
  border-bottom: 1px solid rgba(0,0,0,0.06) !important;
}

/* Today: bar sottile in alto, no background pesante */
.cal-cell--today {
  background: rgba(0,122,255,0.04) !important;
  position: relative;
}
.cal-cell--today::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, #007AFF 0%, #34C759 100%);
}

/* Hover sottile */
.cal-cell:hover:not(.cal-cell--head):not(.cal-cell--pad):not(.cal-cell--week-total) {
  background: rgba(0,0,0,0.02) !important;
  cursor: pointer;
}

/* Numero giorno LEGGIBILE (era piccolo) */
.cell-num {
  font-size: 14px !important;
  font-weight: 600 !important;
  color: var(--text-2) !important;
  margin-bottom: 3px !important;
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.2px;
}
.cal-cell--today .cell-num {
  color: white !important;
  font-weight: 800 !important;
  display: inline-flex !important;
  align-items: center; justify-content: center;
  width: 22px; height: 22px;
  border-radius: 50%;
  background: var(--primary);
}
.cal-cell--active .cell-num {
  color: var(--text) !important;
  font-weight: 700 !important;
}

/* Importo cella PROMINENTE + tabular */
.cell-rev {
  font-size: 15px !important;
  font-weight: 700 !important;
  color: var(--text) !important;
  letter-spacing: -0.3px !important;
  font-variant-numeric: tabular-nums;
}

/* I vecchi banner non vengono più renderizzati dal nuovo design.
   Per sicurezza li nascondo se altri code path li generano. */
#tab-calendario .s1-banner,
#tab-calendario .cal-scad-banner { display: none !important; }

/* Colonna settimana: subtle */
.cal-cell--week-total {
  background: rgba(0,0,0,0.015) !important;
  border-left: 1px solid rgba(0,0,0,0.05) !important;
}
.wt {
  font-size: 11.5px !important;
  font-weight: 600 !important;
  color: var(--text-2) !important;
  letter-spacing: -0.1px !important;
  font-variant-numeric: tabular-nums;
}

/* Badge canale dentro cella più piccoli e arrotondati */
.cell-counts { gap: 3px !important; }
.cc {
  font-size: 9px !important;
  padding: 1px 5px !important;
  border-radius: 4px !important;
  line-height: 1.4;
  font-weight: 700;
  letter-spacing: 0.1px;
}

/* Toolbar mese premium */
.cal-toolbar {
  margin-bottom: var(--s2) !important;
  gap: 6px !important;
  align-items: center;
}
.cal-month-title {
  font-size: 16px !important;
  font-weight: 600 !important;
  min-width: auto !important;
  letter-spacing: -.3px;
  padding-left: 4px;
}
.nav-arrow {
  width: 28px !important; height: 28px !important;
  font-size: 13px !important;
  background: transparent !important;
  border: 1px solid rgba(0,0,0,0.08) !important;
  color: var(--text-2) !important;
  box-shadow: none !important;
}
.nav-arrow:hover {
  background: rgba(0,0,0,0.04) !important;
  color: var(--text) !important;
  border-color: rgba(0,0,0,0.12) !important;
}

/* Banner Suggerimenti e Scadenze: subtle, no border garish */
.s1-banner, .cal-scad-banner {
  background: rgba(0,0,0,0.02) !important;
  border: 1px solid rgba(0,0,0,0.05) !important;
  border-radius: 8px !important;
  padding: 5px 12px !important;
  margin-bottom: var(--s2) !important;
}
.s1-banner-title, .cal-scad-banner-title {
  font-size: 10px !important;
  color: var(--text-3) !important;
  letter-spacing: 0.6px !important;
}
.s1-sug, .cal-scad-item {
  background: var(--card) !important;
  border: 1px solid rgba(0,0,0,0.06) !important;
  border-left-width: 2px !important;
  padding: 3px 9px !important;
  font-size: 11.5px !important;
}

/* Summary calendario ULTRA-COMPATTO: barra orizzontale di 1 riga */
.cal-month-summary {
  margin-top: var(--s2) !important;
  padding: 8px 14px !important;
  border-radius: 10px !important;
  border: 1px solid rgba(0,0,0,0.06) !important;
  box-shadow: 0 1px 2px rgba(0,0,0,0.03) !important;
  background: var(--card);
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  gap: var(--s3) !important;
  flex-wrap: wrap;
}
.month-summary-left {
  display: flex; align-items: center; gap: var(--s2);
  flex-shrink: 0;
}
.month-summary-label {
  font-size: 9.5px !important;
  letter-spacing: 0.6px !important;
  color: var(--text-3) !important;
  text-transform: uppercase;
  font-weight: 600;
}
.month-summary-total { margin-top: 0 !important; line-height: 1; }
.month-total-svg {
  max-width: 110px !important;
  height: 26px !important;
}
/* Totale inline plain text — sostituisce SVG */
.month-summary-total-inline {
  font-size: 18px;
  font-weight: 800;
  letter-spacing: -0.5px;
  color: var(--text);
  font-variant-numeric: tabular-nums;
  background: linear-gradient(135deg, #007AFF 0%, #34C759 50%, #FF9500 100%);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent;
  line-height: 1;
}
.month-summary-breakdown {
  flex: 1; min-width: 0;
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: nowrap !important;
  gap: 6px !important;
  overflow-x: auto;
}
.summary-item {
  flex-shrink: 0 !important;
  padding: 3px 9px !important;
  font-size: 11px !important;
  border-radius: 999px !important;
  background: var(--c-soft, var(--gray-soft)) !important;
  display: inline-flex !important;
  grid-template-columns: none !important;
  align-items: center !important;
  gap: 6px !important;
  border-left: none !important;
  width: auto !important;
}
.summary-item-badge {
  font-weight: 700 !important;
  font-size: 10px !important;
  padding: 1px 6px !important;
  border-radius: 999px !important;
}
.summary-item-meaning { display: none !important; }
.summary-item-amount {
  font-variant-numeric: tabular-nums;
  font-weight: 700 !important;
  font-size: 11px !important;
  color: var(--c-channel, var(--text)) !important;
  letter-spacing: 0 !important;
}

/* Forza summary su una riga sola */
.cal-month-summary {
  flex-wrap: nowrap !important;
}

/* CONTENIMENTO orizzontale strict: niente overflow X dei banner che butta fuori la pagina */
#tab-calendario { overflow-x: hidden; max-width: 100%; }
.s1-banner, .cal-scad-banner { max-width: 100%; overflow: hidden; }
.s1-banner-list, .cal-scad-banner-list {
  flex: 1 1 0; min-width: 0;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}
.s1-banner-list::-webkit-scrollbar, .cal-scad-banner-list::-webkit-scrollbar { display: none; }

/* Celle ancora più basse per fit completo: 6 settimane × 48 = 288 */
.cal-cell, .cal-cell--pad { min-height: 48px !important; }

/* ── CRM Pazienti: 2 grafici in alto più compatti ── */
.crm-stats-row { margin-bottom: var(--s3) !important; gap: var(--s3) !important; }
.stat-chart-card { padding: var(--s3) var(--s4) !important; }
.stat-chart-card h4 { font-size: 12px !important; margin-bottom: var(--s2) !important; }
.chart-canvas-wrap { height: 130px !important; }
/* Conv card a destra: stat numbers e gauge più compatti */
.crm-conv-card .crm-conv-number { font-size: 24px !important; }
.crm-conv-card .crm-conv-label { font-size: 11px !important; }

/* ── Impostazioni: pricing cards più compatte ── */
.acc-sub-card { padding: var(--s3) var(--s4) !important; }
.acc-sub-price { font-size: 28px !important; margin: 2px 0 !important; }
.acc-sub-price span { font-size: 12px !important; }
.acc-sub-features { font-size: 12px !important; margin-top: var(--s2) !important; gap: 2px !important; }
.acc-sub-name { font-size: 11px !important; }
.acc-sub-status { font-size: 14px !important; }

/* ── Impostazioni: user-row e action-row più compatte ── */
.acc-user-row { padding: var(--s2) var(--s3) !important; margin-bottom: var(--s3) !important; }
.acc-user-email { font-size: 14px !important; }
.acc-user-meta { font-size: 11px !important; }
.acc-action-row { padding: var(--s2) var(--s3) !important; }
.acc-action-title { font-size: 13px !important; }
.acc-action-sub { font-size: 11px !important; }

/* ═══════════════════════════════════════════════════════════
   CANALI DI RICAVO — tabella CRUD in Impostazioni
   ═══════════════════════════════════════════════════════════ */
.canali-card { background: linear-gradient(135deg, #ffffff 0%, #f8fbff 100%); }
.canali-table { display: flex; flex-direction: column; gap: 0; margin-top: var(--s3); border: 1px solid var(--border-light); border-radius: var(--r2); overflow: hidden; }
.canali-th, .canali-row {
  display: grid;
  grid-template-columns: 14px 1.8fr 80px 110px 80px 2fr 80px;
  gap: var(--s2);
  align-items: center;
  padding: 8px 12px;
  border-bottom: 1px solid var(--border-light);
}
.canali-row:last-child { border-bottom: none; }
.canali-th {
  background: var(--gray-soft);
  font-size: 10px; font-weight: 700; color: var(--text-2);
  text-transform: uppercase; letter-spacing: .5px;
}
.canali-row { font-size: 13px; background: var(--card); }
.canali-row:hover { background: rgba(0,122,255,.03); }
.canali-row--disabled { opacity: .55; background: var(--gray-soft); }
.canali-color-dot { width: 12px; height: 12px; border-radius: 50%; }
.canali-nome { font-weight: 600; }
.canali-disabled-tag { font-size: 10px; color: var(--text-2); background: rgba(0,0,0,.05); padding: 1px 6px; border-radius: 999px; font-weight: 500; margin-left: 4px; }
.canali-actions { display: flex; gap: 4px; justify-content: flex-end; }
.canali-kws { font-size: 12px; color: var(--text-2); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

.badge-canale {
  display: inline-block;
  padding: 2px 7px;
  font-size: 11px; font-weight: 700;
  border-radius: 999px;
  letter-spacing: .2px;
}

/* Modal color picker per canali */
.canale-color-picker {
  display: flex; flex-wrap: wrap; gap: 6px; align-items: center;
}
.canale-color-btn {
  width: 26px; height: 26px;
  border-radius: 50%;
  border: 2px solid transparent;
  cursor: pointer;
  padding: 0;
  transition: transform .12s, border-color .12s;
}
.canale-color-btn:hover { transform: scale(1.1); }
.canale-color-btn.active { border-color: var(--text); transform: scale(1.1); }

@media (max-width: 720px) {
  .canali-th, .canali-row { grid-template-columns: 14px 1fr 60px 70px; }
  .cth-tariffa, .canali-tariffa, .cth-kws, .canali-kws, .cth-tipo, .canali-tipo { display: none; }
}

/* Tag canale dentro i preset prezzo del calcolatore M6 */
.fisc-preset-tag {
  display: inline-block; margin-left: 4px;
  padding: 1px 5px; border-radius: 6px;
  font-size: 9px; font-weight: 700;
  background: rgba(0,122,255,.12); color: var(--primary);
  vertical-align: middle;
}

/* ═══════════════════════════════════════════════════════════
   PAGE-SPLIT — sidebar left + content right (Fiscalità + Impostazioni)
   Pattern ispirato a Stripe / Vercel / Supabase admin
   ═══════════════════════════════════════════════════════════ */
.page-split {
  display: grid;
  grid-template-columns: 220px minmax(0, 1fr);
  gap: var(--s4);
  align-items: flex-start;
}

.page-nav {
  background: var(--card);
  border: 1px solid var(--border-light);
  border-radius: var(--r3);
  padding: var(--s3) 0 var(--s2);
  position: sticky;
  top: calc(var(--header-h) + var(--s2));
  max-height: calc(100vh - var(--header-h) - var(--s4));
  overflow-y: auto;
  display: flex;
  flex-direction: column;
}

.page-nav-header {
  padding: 0 var(--s3) var(--s3);
  border-bottom: 1px solid var(--border-light);
  margin-bottom: var(--s2);
}
.page-nav-title {
  font-size: 16px; font-weight: 700; color: var(--text);
  letter-spacing: -.3px;
}
.page-nav-sub {
  font-size: 11px; color: var(--text-2);
  margin-top: 2px;
}

.page-nav-list {
  display: flex; flex-direction: column;
  padding: 0 var(--s2);
  gap: 1px;
}

.page-nav-item {
  display: flex; align-items: center; gap: 10px;
  width: 100%;
  padding: 8px 10px;
  background: transparent;
  border: none;
  border-radius: var(--r1);
  font-size: 13px; font-weight: 500;
  color: var(--text-2);
  cursor: pointer;
  text-align: left;
  transition: background .12s, color .12s;
  font-family: inherit;
}
.page-nav-item:hover { background: var(--gray-soft); color: var(--text); }
.page-nav-item.active {
  background: var(--primary-soft);
  color: var(--primary);
  font-weight: 600;
}
.page-nav-icon {
  width: 20px; text-align: center;
  font-size: 14px; flex-shrink: 0;
}
.page-nav-label {
  flex: 1; min-width: 0;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}

.page-nav-footer {
  margin-top: auto;
  padding: var(--s3) var(--s3) 0;
  border-top: 1px solid var(--border-light);
  font-size: 10px;
  color: var(--text-3);
  line-height: 1.5;
}

.page-content {
  min-width: 0;
}
.page-content > .settings-card,
.page-content > .fisc-card,
.page-content > .canali-card {
  margin-bottom: var(--s3);
}

/* Mobile: stack verticale, sidebar diventa tab orizzontali */
@media (max-width: 880px) {
  .page-split { grid-template-columns: 1fr; gap: var(--s2); }
  .page-nav {
    position: static; max-height: none;
    padding: var(--s2) 0;
    border-radius: var(--r2);
  }
  .page-nav-header { display: none; }
  .page-nav-list {
    flex-direction: row;
    overflow-x: auto;
    padding: 0 var(--s2);
    gap: 4px;
    scrollbar-width: thin;
  }
  .page-nav-item {
    flex-shrink: 0;
    padding: 8px 12px;
  }
  .page-nav-item.active { background: var(--primary); color: white; }
  .page-nav-footer { display: none; }
}

/* ═══════════════════════════════════════════════════════════
   GUIDA — help center (Stripe Docs / Vercel Docs style)
   ═══════════════════════════════════════════════════════════ */
.guide-card {
  background: var(--card);
  border: 1px solid var(--border-light);
  border-radius: var(--r3);
  padding: var(--s5) var(--s5) var(--s4);
  max-width: 820px;
}
.guide-card h2 {
  font-size: 22px; font-weight: 800;
  letter-spacing: -.5px;
  margin: 0 0 6px;
  color: var(--text);
}
.guide-card h3 {
  font-size: 15px; font-weight: 700;
  margin: var(--s4) 0 var(--s2);
  color: var(--text);
}
.guide-card .guide-lead {
  font-size: 14px;
  color: var(--text-2);
  line-height: 1.6;
  margin: 0 0 var(--s3);
}
.guide-card p { font-size: 13px; line-height: 1.6; color: var(--text-2); margin: 0 0 var(--s2); }
.guide-card code {
  background: rgba(0,0,0,0.06);
  padding: 1px 6px; border-radius: 4px;
  font-family: 'SF Mono', Menlo, Consolas, monospace;
  font-size: 12px;
  color: var(--text);
}

.guide-list {
  margin: var(--s2) 0; padding-left: var(--s4);
  font-size: 13px; color: var(--text-2); line-height: 1.7;
}
.guide-list li { margin-bottom: 4px; }
.guide-list li b { color: var(--text); }

.guide-steps {
  list-style: none; padding: 0;
  display: flex; flex-direction: column; gap: var(--s2);
  margin: var(--s2) 0;
}
.guide-step {
  display: flex; gap: var(--s2);
  font-size: 13px; line-height: 1.5;
}
.guide-step-num {
  flex-shrink: 0;
  width: 22px; height: 22px;
  background: var(--primary-soft);
  color: var(--primary);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-weight: 700; font-size: 12px;
}
.guide-step-text { color: var(--text-2); padding-top: 1px; }
.guide-step-text b { color: var(--text); }

/* Callout boxes */
.guide-callout {
  display: flex; gap: 10px; align-items: flex-start;
  padding: 10px 14px;
  border-radius: var(--r2);
  margin: var(--s3) 0;
  font-size: 13px; line-height: 1.55;
}
.guide-callout-icon { font-size: 16px; flex-shrink: 0; line-height: 1.2; }
.guide-callout--tip  { background: rgba(52,199,89,.08);  border-left: 3px solid #34C759; color: #14532D; }
.guide-callout--warn { background: rgba(255,149,0,.08);  border-left: 3px solid #FF9500; color: #7C2D12; }
.guide-callout--info { background: rgba(0,122,255,.08);  border-left: 3px solid #007AFF; color: #0A4DA2; }
.guide-callout b { color: var(--text); }
.guide-callout code { background: rgba(0,0,0,0.06); color: var(--text); }

/* Shortcut buttons (link interni "vai a") */
.guide-shortcuts {
  display: flex; flex-wrap: wrap; gap: var(--s2);
  margin-top: var(--s4);
  padding-top: var(--s3);
  border-top: 1px solid var(--border-light);
}
.guide-go-btn {
  background: var(--card);
  border: 1px solid var(--primary);
  color: var(--primary);
  padding: 7px 14px;
  border-radius: var(--r2);
  font-size: 12.5px; font-weight: 600;
  cursor: pointer;
  transition: all .12s;
}
.guide-go-btn:hover {
  background: var(--primary);
  color: white;
}

/* ═══════════════════════════════════════════════════════════
   FISCALITÀ — compattazione 3 sezioni per fit viewport laptop
   Scenario annuo, Accantonamento, Netto per seduta
   ═══════════════════════════════════════════════════════════ */
/* Card più compatte quando in sidebar (page-content wrapper) */
.page-content .fisc-card {
  padding: var(--s3) var(--s4) !important;
  margin-bottom: var(--s3);
}
.page-content .fisc-card h3 { font-size: 15px !important; margin-bottom: 6px; }
.page-content .fisc-card-sub { font-size: 12px; margin-bottom: var(--s2); }
.page-content .fisc-card h4.fisc-section-h4 {
  font-size: 11px;
  margin: var(--s2) 0 var(--s1);
}

/* Scenario annuo: header + input più compatti */
.page-content .fisc-scenario-header {
  margin-bottom: var(--s2) !important;
}
.page-content .fisc-input--big { font-size: 22px !important; padding: 8px 12px !important; }

/* Simulatore: KPI row più stretti */
.page-content .fisc-kpi-row {
  gap: var(--s2) !important;
  margin: var(--s2) 0 !important;
}
.page-content .fisc-kpi { padding: 10px 12px !important; }
.page-content .fisc-kpi-label { font-size: 10px !important; }
.page-content .fisc-kpi-value { font-size: 18px !important; }
.page-content .fisc-kpi-sub { font-size: 10px !important; margin-top: 2px; }

/* Tabella scomposizione fattura più compatta */
.page-content .fisc-breakdown {
  font-size: 12px !important;
  margin-top: var(--s2);
}
.page-content .fisc-breakdown td,
.page-content .fisc-breakdown th { padding: 4px 8px !important; }

/* Accantonamento chart più piccolo */
.page-content .fisc-accant-chart-wrap {
  height: 170px !important;
  margin: var(--s2) 0 !important;
}

/* Tabella mesi accantonamento più compatta */
.page-content .fisc-accant-table {
  font-size: 12px !important;
}
.page-content .fisc-accant-table td,
.page-content .fisc-accant-table th { padding: 4px 8px !important; }
.page-content .fisc-accant-input {
  width: 70px !important; padding: 4px 6px !important; font-size: 12px !important;
}

/* Netto per seduta: tutto inline */
.page-content .fisc-seduta-row {
  gap: var(--s2) !important;
  margin-bottom: var(--s2) !important;
}
.page-content .fisc-preset {
  padding: 5px 9px !important; font-size: 11px !important;
}
.page-content .fisc-preset.active { font-weight: 700 !important; }

/* FAQ */
.guide-faq { display: flex; flex-direction: column; gap: var(--s3); margin-top: var(--s3); }
.guide-faq-q {
  font-weight: 700; color: var(--text);
  font-size: 14px;
  padding-top: var(--s2);
}
.guide-faq-a {
  font-size: 13px; color: var(--text-2); line-height: 1.6;
  padding-bottom: var(--s3);
  border-bottom: 1px solid var(--border-light);
}
.guide-faq-a:last-child { border-bottom: none; }
.guide-faq-a a { color: var(--primary); }

/* ── Card sezioni: padding ridotti su tutte le tab ── */
.settings-card { padding: var(--s4) !important; }
.settings-card h3 { font-size: 14px !important; margin-bottom: var(--s2) !important; }
.fisc-card { padding: var(--s3) var(--s4) !important; }
.fisc-card h3 { font-size: 14px; }
.fisc-card h4.fisc-section-h4 { margin: var(--s3) 0 var(--s1); font-size: 12px; }
.fisc-card-sub { margin-bottom: var(--s2); }

/* ── CRM: toolbar sticky + lista scrollabile ── */
.crm-toolbar {
  position: sticky;
  top: var(--header-h);
  background: var(--bg);
  z-index: 50;
  padding-top: var(--s2);
  padding-bottom: var(--s2);
}

/* ── Forms più compatti (input/select/textarea) ── */
.form-input, .form-select { padding: 7px var(--s3) !important; font-size: 13px !important; }
.form-textarea { min-height: 48px; }
.form-label { font-size: 11px; }
.form-section { padding: var(--s3); }
.form-section-title { font-size: 10px; }

/* ── Bottoni leggermente più compatti ── */
.btn-primary, .btn-secondary { padding: 7px var(--s3); font-size: 12.5px; }
.btn-ghost { padding: 5px var(--s2); font-size: 12px; }

