/* ═══════════════════════════════════════════════════════════════
   CAI DIGITALE — BAREMES (crocette responsabilità)
   Griglia di caselle che mappano le dinamiche del sinistro.
   In produzione: il backend mappa le selezioni alle percentuali
═══════════════════════════════════════════════════════════════ */
.baremes-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  margin-bottom: 20px;
}
.bareme-item {
  border: 1.5px solid #E5E7EB;
  border-radius: var(--radius-sm);
  padding: 12px;
  cursor: pointer;
  transition: var(--transition);
  display: flex;
  align-items: flex-start;
  gap: 10px;
  background: white;
}
.bareme-item:hover { border-color: var(--sg-green); background: var(--sg-green-light); }
.bareme-item.selected { border-color: var(--sg-green); background: var(--sg-green-light); }
.bareme-check {
  width: 20px; height: 20px;
  border: 2px solid #D1D5DB;
  border-radius: 4px;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  margin-top: 1px;
  transition: var(--transition);
  font-size: 12px;
  color: white;
}
.bareme-item.selected .bareme-check {
  background: var(--sg-green);
  border-color: var(--sg-green);
}
.bareme-text { font-size: 13px; color: var(--sg-black); line-height: 1.4; font-weight: 500; }

/* Griglia checkbox danni visibili (Sez. 11) */
.danni-check-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4px;
}
.danni-check {
  display: flex; align-items: center; gap: 6px;
  font-size: 12px; font-weight: 500; color: var(--sg-black);
  padding: 7px 8px; border-radius: 6px;
  border: 1.5px solid #E5E7EB; background: white;
  cursor: pointer; transition: var(--transition);
  user-select: none;
}
.danni-check:has(input:checked) {
  border-color: var(--sg-green); background: var(--sg-green-light);
  color: var(--sg-green-dark); font-weight: 600;
}
.danni-check input { width: 16px; height: 16px; accent-color: var(--sg-green); flex-shrink: 0; }

/* Grafico punto d'urto — selezione zona veicolo */
.urto-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 6px;
  margin-bottom: 20px;
}
.urto-btn {
  border: 1.5px solid #E5E7EB;
  border-radius: var(--radius-sm);
  padding: 10px 6px;
  text-align: center;
  cursor: pointer;
  font-size: 11px;
  font-weight: 600;
  color: var(--sg-gray);
  background: white;
  transition: var(--transition);
}
.urto-btn:hover { border-color: var(--sg-green); color: var(--sg-green-dark); }
.urto-btn.selected { border-color: var(--sg-green); background: var(--sg-green); color: white; }
.urto-btn .urto-icon { font-size: 20px; display: block; margin-bottom: 4px; }
/* SVG urto zones */
.urto-zone { transition: fill 0.2s; }
.urto-zone:hover { fill: rgba(255,184,0,0.18) !important; }
.urto-zone.selected { fill: rgba(255,184,0,0.38) !important; stroke: var(--cg-gold); stroke-width: 2; }
.urto-zone-b.selected { fill: rgba(198,40,40,0.25) !important; stroke: #C62828; stroke-width: 2; }
/* Bareme number badge */
.bareme-num {
  min-width: 24px; height: 24px; border-radius: 50%;
  background: var(--sg-gray-light); color: var(--sg-gray);
  display: flex; align-items: center; justify-content: center;
  font-size: 11px; font-weight: 700; flex-shrink: 0;
}
.bareme-item.selected .bareme-num {
  background: var(--sg-green); color: white;
}
/* CAI Visual Module */
.cai-section {
  background: white; border: 1px solid #E5E7EB; border-radius: var(--radius-sm);
  padding: 12px; margin-bottom: 12px;
}
.cai-section-header {
  display: flex; align-items: center; gap: 8px;
  margin-bottom: 10px; padding-bottom: 8px; border-bottom: 1px solid #F3F4F6;
  font-size: 13px; font-weight: 600; color: var(--sg-black);
}
.cai-section-num {
  min-width: 22px; height: 22px; border-radius: 50%;
  background: var(--sg-black); color: white;
  display: flex; align-items: center; justify-content: center;
  font-size: 10px; font-weight: 700; flex-shrink: 0;
}
.cai-auto-badge {
  margin-left: auto; font-size: 9px; text-transform: uppercase;
  background: var(--sg-green-light); color: var(--sg-green-dark);
  padding: 2px 8px; border-radius: 4px; font-weight: 600; letter-spacing: 0.5px;
}
.cai-field-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 8px;
}
.cai-field {
  background: var(--sg-gray-light); border-radius: 6px; padding: 8px 10px;
}
.cai-field-label {
  display: block; font-size: 9px; text-transform: uppercase; letter-spacing: 0.5px;
  color: var(--sg-gray); margin-bottom: 2px;
}
.cai-field-value {
  display: block; font-size: 14px; font-weight: 600; color: var(--sg-black);
}
.cai-field-targa {
  font-family: monospace; font-size: 16px; letter-spacing: 2px;
}

/* ═══════════════════════════════════════════════════════════════
   CAI MODULO BLU — Stile autentico Constatazione Amichevole
   Riproduzione digitale fedele del modulo cartaceo ufficiale
═══════════════════════════════════════════════════════════════ */
.cai-blue-header {
  background: linear-gradient(135deg, #1565C0, #0D47A1);
  color: white;
  padding: 16px;
  border-radius: var(--radius-md);
  margin-bottom: 16px;
  border: 2px solid #0D47A1;
  position: relative;
  overflow: hidden;
}
.cai-blue-header::before {
  content: '';
  position: absolute;
  top: 0; right: 0;
  width: 60px; height: 60px;
  background: rgba(255,255,255,0.08);
  border-radius: 0 0 0 60px;
}
.cai-blue-header .cai-modulo-label {
  font-size: 9px; text-transform: uppercase; letter-spacing: 1.5px;
  opacity: 0.7; margin-bottom: 4px;
}
.cai-blue-header .cai-modulo-title {
  font-family: var(--font-display);
  font-size: 18px; font-weight: 800; line-height: 1.15;
  margin-bottom: 6px;
}
.cai-blue-header .cai-modulo-sub {
  font-size: 10px; opacity: 0.65; line-height: 1.4;
}
.cai-blue-header .cai-modulo-art {
  font-size: 9px; opacity: 0.5; margin-top: 8px;
  border-top: 1px solid rgba(255,255,255,0.15);
  padding-top: 6px;
}
.cai-blue-header .cai-badge-digitale {
  position: absolute; top: 12px; right: 12px;
  background: var(--sg-green); color: white;
  font-size: 9px; font-weight: 700;
  padding: 3px 10px; border-radius: 10px;
  text-transform: uppercase; letter-spacing: 0.5px;
}

/* CAI vehicle tabs A/B */
.cai-vehicle-tabs {
  display: flex; gap: 0; margin-bottom: 16px;
  border-radius: var(--radius-sm);
  overflow: hidden;
  border: 2px solid #E5E7EB;
}
.cai-vehicle-tab {
  flex: 1; padding: 12px 8px;
  text-align: center; cursor: pointer;
  font-size: 13px; font-weight: 700;
  font-family: var(--font-display);
  transition: var(--transition);
  border: none; background: white;
  color: var(--sg-gray);
}
.cai-vehicle-tab.tab-a { border-right: 1px solid #E5E7EB; }
.cai-vehicle-tab.tab-a.active { background: #1565C0; color: white; }
.cai-vehicle-tab.tab-b.active { background: #C62828; color: white; }
.cai-vehicle-tab .tab-letter {
  display: block; font-size: 22px; font-weight: 800; line-height: 1;
}
.cai-vehicle-tab .tab-label {
  display: block; font-size: 10px; margin-top: 2px; text-transform: uppercase;
  letter-spacing: 0.5px;
}

/* Vehicle panel content */
.cai-vehicle-panel { display: none; }
.cai-vehicle-panel.active { display: block; }

/* CAI section with blue/red accent per vehicle */
.cai-section-a { border-left: 3px solid #1565C0; }
.cai-section-b { border-left: 3px solid #C62828; }
.cai-section-a .cai-section-num { background: #1565C0; }
.cai-section-b .cai-section-num { background: #C62828; }

/* CAI editable input fields (for Vehicle B / manual entry) */
.cai-field-input {
  display: block; width: 100%;
  font-size: 16px; font-weight: 600; color: var(--sg-black); /* iOS no-zoom */
  background: white; border: 1.5px solid #E5E7EB;
  border-radius: 4px; padding: 6px 8px;
  font-family: var(--font-body);
  outline: none; transition: var(--transition);
}
.cai-field-input:focus {
  border-color: #1565C0;
  box-shadow: 0 0 0 2px rgba(21,101,192,0.12);
}
.cai-field-input.field-b:focus {
  border-color: #C62828;
  box-shadow: 0 0 0 2px rgba(198,40,40,0.12);
}
.cai-field-input::placeholder {
  color: #B0BEC5; font-weight: 400; font-size: 12px;
}

/* CAI Feriti / Testimoni toggle */
.cai-toggle-row {
  display: flex; gap: 8px; align-items: center;
  margin-bottom: 8px;
}
.cai-toggle-btn {
  flex: 1; padding: 10px;
  border: 1.5px solid #E5E7EB; border-radius: var(--radius-sm);
  background: white; cursor: pointer;
  font-size: 14px; font-weight: 600;
  text-align: center; transition: var(--transition);
  font-family: var(--font-body); color: var(--sg-gray);
}
.cai-toggle-btn.active-si { border-color: #C62828; background: #FFEBEE; color: #C62828; }
.cai-toggle-btn.active-no { border-color: var(--sg-green); background: var(--sg-green-light); color: var(--sg-green-dark); }

/* Witness card */
.cai-witness-card {
  background: var(--sg-gray-light); border-radius: var(--radius-sm);
  padding: 12px; margin-bottom: 8px;
}
.cai-witness-card .cai-field-grid { margin-bottom: 0; }

/* CAI sketch canvas */
.cai-sketch-container {
  border: 2px solid #E5E7EB;
  border-radius: var(--radius-md);
  overflow: hidden;
  margin-bottom: 12px;
  background: white;
  position: relative;
}
.cai-sketch-container canvas {
  display: block; width: 100%;
  touch-action: none; cursor: crosshair;
}
.cai-sketch-toolbar {
  display: flex; gap: 6px; padding: 8px;
  background: var(--sg-gray-light);
  border-top: 1px solid #E5E7EB;
}
.cai-sketch-btn {
  flex: 1; padding: 6px;
  border: 1px solid #E5E7EB; border-radius: 6px;
  background: white; cursor: pointer;
  font-size: 11px; font-weight: 600;
  font-family: var(--font-body);
  color: var(--sg-gray); text-align: center;
  transition: var(--transition);
}
.cai-sketch-btn.active { background: var(--sg-black); color: white; border-color: var(--sg-black); }
.cai-sketch-btn:hover { border-color: var(--sg-black); }

/* CAI textarea for observations */
.cai-textarea {
  width: 100%; min-height: 80px;
  border: 1.5px solid #E5E7EB; border-radius: var(--radius-sm);
  padding: 10px; font-family: var(--font-body);
  font-size: 16px; color: var(--sg-black); /* iOS no-zoom */
  resize: vertical; outline: none;
  transition: var(--transition);
}
.cai-textarea:focus {
  border-color: #1565C0;
  box-shadow: 0 0 0 2px rgba(21,101,192,0.12);
}

/* CAI damage description */
.cai-damage-area {
  width: 100%; min-height: 60px;
  border: 1.5px dashed #E5E7EB; border-radius: var(--radius-sm);
  padding: 10px; font-family: var(--font-body);
  font-size: 16px; color: var(--sg-black); /* iOS no-zoom */
  resize: vertical; outline: none;
  background: #FAFAFA;
}
.cai-damage-area:focus {
  border-color: #1565C0; border-style: solid;
  background: white;
}

/* CAI form step indicator */
.cai-step-dots {
  display: flex; justify-content: center; gap: 6px;
  margin-bottom: 16px;
}
.cai-step-dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: #E5E7EB; transition: var(--transition);
}
.cai-step-dot.active { background: #1565C0; width: 24px; border-radius: 4px; }
.cai-step-dot.done { background: var(--sg-green); }

/* CAI compact summary for confirmation */
.cai-confirm-section {
  background: white; border: 1px solid #E5E7EB;
  border-radius: var(--radius-sm); padding: 12px;
  margin-bottom: 10px;
}
.cai-confirm-title {
  font-size: 11px; text-transform: uppercase;
  letter-spacing: 0.5px; color: var(--sg-gray);
  font-weight: 700; margin-bottom: 8px;
  display: flex; align-items: center; gap: 6px;
}
.cai-confirm-title .dot-a { width: 8px; height: 8px; border-radius: 50%; background: #1565C0; }
.cai-confirm-title .dot-b { width: 8px; height: 8px; border-radius: 50%; background: #C62828; }
.cai-confirm-row {
  display: flex; justify-content: space-between;
  padding: 4px 0; font-size: 13px;
}
.cai-confirm-row .label { color: var(--sg-gray); }
.cai-confirm-row .value { font-weight: 600; color: var(--sg-black); text-align: right; max-width: 60%; }

/* Dual vehicle impact comparison */
.cai-dual-impact {
  display: grid; grid-template-columns: 1fr 1fr; gap: 12px;
  margin-bottom: 16px;
}
.cai-dual-impact .impact-col {
  text-align: center;
}
.cai-dual-impact .impact-col h4 {
  font-size: 11px; text-transform: uppercase;
  letter-spacing: 0.5px; margin-bottom: 8px;
  font-weight: 700;
}
.cai-dual-impact .impact-col.col-a h4 { color: #1565C0; }
.cai-dual-impact .impact-col.col-b h4 { color: #C62828; }

/* Small vehicle SVG for dual view */
.cai-dual-impact svg { max-width: 120px; }

/* Insurance info compact */
.cai-insurance-badge {
  display: inline-flex; align-items: center; gap: 4px;
  background: var(--sg-gray-light);
  padding: 4px 10px; border-radius: 99px;
  font-size: 11px; font-weight: 600; color: var(--sg-gray);
  margin-bottom: 8px;
}

/* Baremes compact for dual */
.baremes-grid-compact {
  display: grid;
  grid-template-columns: 1fr;
  gap: 6px;
  margin-bottom: 12px;
}
.baremes-grid-compact .bareme-item {
  padding: 8px 10px;
}
.baremes-grid-compact .bareme-text {
  font-size: 12px;
}

/* Baremes dual A|text|B layout (like real CAI paper form) */
.bareme-dual-row {
  display: grid;
  grid-template-columns: 36px 1fr 36px;
  gap: 4px;
  align-items: center;
  padding: 6px 2px;
  border-bottom: 1px solid #F3F4F6;
}
.bareme-dual-row:last-child { border-bottom: none; }
.bareme-chk-a, .bareme-chk-b {
  width: 28px; height: 28px;
  border: 2px solid #D1D5DB;
  border-radius: 4px;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  transition: var(--transition);
  font-size: 14px; font-weight: 700; color: white;
  margin: 0 auto;
}
.bareme-chk-a:hover { border-color: #1565C0; background: #E3F2FD; }
.bareme-chk-b:hover { border-color: #C62828; background: #FFEBEE; }
.bareme-chk-a.checked { background: #1565C0; border-color: #1565C0; }
.bareme-chk-b.checked { background: #C62828; border-color: #C62828; }
/* Casella disabilitata: combinazione non verificabile col lato opposto */
.bareme-chk-a.bareme-chk-disabled,
.bareme-chk-b.bareme-chk-disabled {
  opacity: 0.28;
  background: repeating-linear-gradient(45deg, #E0E0E0, #E0E0E0 3px, #F5F5F5 3px, #F5F5F5 6px);
  border-color: #BDBDBD;
  cursor: not-allowed;
  pointer-events: auto;  /* lasciamo il click per intercettarlo via JS e mostrare il toast */
}
.bareme-chk-a.bareme-chk-disabled:hover,
.bareme-chk-b.bareme-chk-disabled:hover { border-color: #BDBDBD; background: repeating-linear-gradient(45deg, #E0E0E0, #E0E0E0 3px, #F5F5F5 3px, #F5F5F5 6px); }
.bareme-center {
  display: flex; align-items: flex-start; gap: 6px;
  padding: 0 4px;
}
.bareme-center .bareme-num {
  min-width: 20px; height: 20px;
  font-size: 10px;
}
.bareme-center .bareme-text {
  font-size: 12px; line-height: 1.3;
}

/* ═══════════════════════════════════════════════════════════════
   CID UFFICIALE — Modulo cartaceo italiano
   Replica fedele con tabelle, colori e proporzioni esatte
═══════════════════════════════════════════════════════════════ */
.cid-scroll { overflow-y: auto; -webkit-overflow-scrolling: touch; }
.cid-a4 {
  background: white; border: 2px solid #000;
  font: 9px/1.4 Arial, Helvetica, sans-serif; color: #231f20;
  max-width: 800px; margin: 4px auto;
  box-shadow: 0 4px 20px rgba(0,0,0,0.3);
}
/* Tabella base */
.cid-t { width: 100%; border-collapse: collapse; }
.cid-t td { border: 1px solid #888; padding: 3px 5px; vertical-align: top; }
/* Giallo sezioni chiave */
.cid-yy { background: #FFF8DC; }
/* Etichette */
.cid-h { font: bold 8px/1.3 Arial, sans-serif; color: #231f20; text-transform: uppercase; }
.cid-note { font: normal 7px/1.2 Arial, sans-serif; color: #555; text-transform: none; }
.cid-sh { font: bold 8px/1.3 Arial, sans-serif; color: #231f20; text-transform: uppercase; padding: 2px 3px 1px; margin: 4px 0 2px; border-bottom: 1px solid #AAA; }
/* Checkbox inline */
.cid-ck { font: 8px sans-serif; margin-left: 3px; white-space: nowrap; }
.cid-ck input { width: 11px; height: 11px; vertical-align: middle; margin: 0 1px 0 0; }
/* Input compilabile */
.ci {
  border: none; border-bottom: 1px solid #777; background: transparent;
  font: 600 10px/1.4 Arial, sans-serif; color: #231f20; padding: 1px 2px;
  outline: none; width: 100%; box-sizing: border-box;
}
.ci:focus { border-bottom: 2px solid #1565C0; background: #FAFEFF; }
.cid-tg { font: 800 13px/1.3 monospace !important; letter-spacing: 3px; color: #1565C0 !important; }
/* Textarea */
.ci-ta {
  width: 100%; min-height: 35px; border: 1px solid #BBB; font: 9px/1.4 Arial, sans-serif;
  color: #231f20; padding: 3px; resize: vertical; outline: none; box-sizing: border-box;
}
.ci-ta:focus { border-color: #1565C0; background: #FAFEFF; }
/* Field row */
.cid-f { font: 8px/1.5 Arial, sans-serif; color: #555; display: flex; align-items: baseline; gap: 3px; margin-bottom: 2px; }
.cid-f .ci { flex: 1; min-width: 20px; }
.cid-f2 { font: 8px/1.5 Arial, sans-serif; color: #555; display: flex; align-items: baseline; gap: 3px; margin-bottom: 2px; flex-wrap: wrap; }
.cid-f2 .ci { width: 40px; flex: none; }
/* Colonne A/C/B */
.cid-main td { padding: 0; }
.cid-col-a { background: #E3F2FD; border-right: 3px solid #1976D2 !important; padding: 4px 5px !important; }
.cid-col-b { background: #FFEBEE; border-left: 3px solid #D32F2F !important; padding: 4px 5px !important; }
.cid-col-c { background: #FAFAFA; padding: 0 4px !important; border-left: 1px solid #CCC !important; border-right: 1px solid #CCC !important; }
.cid-colh { text-align: center; font: bold 13px/1.4 Arial, sans-serif; color: #fff; padding: 5px; margin: 0 -5px 5px; text-transform: uppercase; letter-spacing: 1px; }
.cid-colh-a { background: #1976D2; margin: 0 -5px 5px; }
.cid-colh-b { background: #D32F2F; margin: 0 -5px 5px; }
.cid-colh-c { background: #388E3C; margin: 0 -3px 2px; font-size: 10px; padding: 4px; letter-spacing: 0.5px; }
/* Punto d'urto */
.cid-urto { text-align: center; font: bold 14px sans-serif; color: #1565C0; padding: 6px; min-height: 22px; }
/* Baremes */
.cid-bar { width: 100%; border-collapse: collapse; }
.cid-bar td { border-bottom: 1px solid #DDD; padding: 1.5px 1px; vertical-align: middle; border-left: none; border-right: none; border-top: none; }
.cid-bar .ba, .cid-bar .bb { width: 22px; text-align: center; }
.cid-bar .ba input, .cid-bar .bb input { width: 15px; height: 15px; }
.cid-bar .ba { background: #E8F4FD; }
.cid-bar .ba input { accent-color: #1565C0; }
.cid-bar .bb { background: #FFF0F0; }
.cid-bar .bb input { accent-color: #C62828; }
.cid-bar .bn { width: 16px; text-align: center; font: bold 7px sans-serif; color: #555; }
.cid-bar .bt { font: 8px/1.3 Arial, sans-serif; color: #231f20; padding-left: 3px; }
/* Print */
@media print {
  .no-print, .header, .sticky-bottom, .debug-panel, .toast { display: none !important; }
  .screen { display: block !important; max-width: 100% !important; min-height: auto !important; animation: none !important; }
  .screen:not(#s7p) { display: none !important; }
  #s7p { display: block !important; }
  #s7p .content, .cid-scroll { padding: 0 !important; background: white !important; overflow: visible !important; }
  .cid-a4 { border: none; margin: 0; max-width: 100%; }
  body { background: white !important; margin: 0 !important; }
}

/* ═══════════════════════════════════════════════════════════════
   CAI MODULO UFFICIALE — Replica fedele del modulo cartaceo
   Giallo intestazione, blu colonna A, rosa colonna B, verde circostanze
═══════════════════════════════════════════════════════════════ */
.cai-mod {
  background: white;
  border: 2px solid #999;
  border-radius: 2px;
  font-size: 9px;
  color: #1A1A2E;
  overflow: hidden;
}
.cai-mod-head {
  background: #FFF9C4;
  border-bottom: 2px solid #F9A825;
  padding: 8px 10px;
  text-align: center;
}
/* Righe dati comuni (1-5) */
.cai-mod-toprow {
  display: flex;
  border-bottom: 1px solid #999;
}
.cai-mod-cell {
  flex: 1;
  padding: 4px 6px;
  border-right: 1px solid #CCC;
}
.cai-mod-cell:last-child { border-right: none; }
.cai-mod-clabel {
  font-size: 7px;
  font-weight: 600;
  color: #555;
  text-transform: uppercase;
}
.cai-mod-cval {
  font-size: 10px;
  font-weight: 700;
  color: #1A1A2E;
  border-bottom: 1px solid #333;
  min-height: 14px;
  padding: 1px 2px;
}
/* Tre colonne A | Circostanze | B */
.cai-mod-cols {
  display: grid;
  grid-template-columns: 1fr minmax(110px, auto) 1fr;
  border-top: 2px solid #999;
}
.cai-mod-col { padding: 4px 5px; }
.cai-mod-col-a {
  background: #E3F2FD;
  border-right: 2px solid #42A5F5;
}
.cai-mod-col-b {
  background: #FFEBEE;
  border-left: 2px solid #EF5350;
}
.cai-mod-col-c {
  background: #F1F8E9;
  padding: 0 3px;
}
.cai-mod-col-head {
  text-align: center;
  font-family: var(--font-display);
  font-size: 11px;
  font-weight: 700;
  color: white;
  padding: 4px;
  margin: -4px -5px 4px -5px;
  text-transform: uppercase;
}
.cai-mod-sec {
  font-size: 7px;
  font-weight: 700;
  color: #333;
  text-transform: uppercase;
  letter-spacing: 0.2px;
  margin: 5px 0 2px;
  padding: 1px 3px;
  background: rgba(0,0,0,0.04);
  border-bottom: 1px solid rgba(0,0,0,0.08);
}
.cai-mod-f {
  display: flex;
  align-items: baseline;
  gap: 3px;
  margin-bottom: 1px;
  font-size: 7px;
  color: #888;
  line-height: 1.5;
}
.cai-mod-f span { white-space: nowrap; }
.cai-mod-f b {
  font-size: 9px;
  color: #1A1A2E;
  font-weight: 600;
  word-break: break-word;
  border-bottom: 1px solid #AAA;
  flex: 1;
  min-height: 11px;
}
.cai-mod-targa {
  font-family: monospace;
  letter-spacing: 1.5px;
  font-size: 11px !important;
  font-weight: 800 !important;
}
.cai-mod-text {
  font-size: 8px;
  color: #333;
  line-height: 1.4;
  padding: 2px 0;
  min-height: 16px;
  border-bottom: 1px solid #DDD;
}
/* Tabella circostanze — layout A|n|testo|n|B */
.cai-mod-baremes {
  width: 100%;
  border-collapse: collapse;
  font-size: 7px;
}
.cai-mod-baremes td {
  padding: 1.5px 1px;
  border-bottom: 1px solid #DDD;
  vertical-align: middle;
}
.cai-mod-baremes .bA,
.cai-mod-baremes .bB {
  width: 18px;
  height: 16px;
  text-align: center;
  font-weight: 800;
  font-size: 9px;
  border: 1px solid #BBB;
  background: white;
}
.cai-mod-baremes .bA { color: #1565C0; }
.cai-mod-baremes .bB { color: #C62828; }
.cai-mod-baremes .bN {
  width: 14px;
  text-align: center;
  font-weight: 700;
  font-size: 7px;
  color: #666;
}
.cai-mod-baremes .bT {
  font-size: 7px;
  color: #333;
  padding-left: 2px;
  line-height: 1.2;
}
/* Footer: osservazioni + firma */
.cai-mod-footer {
  display: flex;
  border-top: 2px solid #999;
  font-size: 8px;
}
.cai-mod-footer > div {
  padding: 4px 5px;
}
/* Mobile: stack columns */
@media (max-width: 430px) {
  .cai-mod-cols { grid-template-columns: 1fr; }
  .cai-mod-col-a { border-right: none; border-bottom: 2px solid #42A5F5; }
  .cai-mod-col-b { border-left: none; border-top: 2px solid #EF5350; }
  .cai-mod-col-c { border-top: 1px solid #999; border-bottom: 1px solid #999; }
  .cai-mod-footer { flex-direction: column; }
  .cai-mod-footer > div { border-left: none !important; border-right: none !important; border-bottom: 1px solid #CCC; }
}

/* ═══════════════════════════════════════════════════════════════
   OTP FIRMA — input codice e firma digitale
   In produzione: server genera OTP → invia via SMS → utente inserisce
═══════════════════════════════════════════════════════════════ */
.otp-display {
  text-align: center;
  margin: 20px 0;
}
.otp-code {
  font-family: var(--font-display);
  font-size: 42px;
  font-weight: 800;
  color: var(--sg-green);
  letter-spacing: 12px;
  display: block;
  margin-bottom: 8px;
}
.otp-hint { font-size: 13px; color: var(--sg-gray); }
.otp-input-row {
  display: flex;
  gap: 8px;
  justify-content: center;
  margin: 20px 0;
}
.otp-digit {
  width: 50px; height: 60px;
  border: 2px solid #E5E7EB;
  border-radius: var(--radius-sm);
  text-align: center;
  font-family: var(--font-display);
  font-size: 24px;
  font-weight: 700;
  color: var(--sg-black);
  outline: none;
  transition: var(--transition);
}
.otp-digit:focus { border-color: var(--cg-petrol); box-shadow: 0 0 0 3px rgba(11,93,102,0.15); }

/* Firma canvas */
.firma-canvas-container {
  border: 2px dashed #E5E7EB;
  border-radius: var(--radius-md);
  overflow: hidden;
  margin-bottom: 12px;
  background: #FAFAFA;
  position: relative;
}
#firmaCanvas {
  display: block;
  width: 100%;
  touch-action: none;
  cursor: crosshair;
}
.firma-clear {
  position: absolute;
  top: 8px; right: 8px;
  background: rgba(0,0,0,0.15);
  border: none;
  color: white;
  font-size: 11px;
  padding: 4px 10px;
  border-radius: 99px;
  cursor: pointer;
  font-family: var(--font-body);
}

