:root {
  --primary: #e67a2e;
  --primary-light: #fff5eb;
  --primary-mid: #f9c07a;
  --primary-dark: #f9c07a;
  --primary-header: #e67a2e;
  --success: #27ae60;
  --warning: #e67a2e;
  --danger: #e74c3c;
  --info: #2980b9;
  --gr100: #f8f9fa;
  --gr200: #f0f2f5;
  --gr300: #dee2e6;
  --gr400: #ced4da;
  --gr500: #adb5bd;
  --gr600: #6c757d;
  --gr800: #343a40;
  --text: #adb5bd;
  --bgc: #ffffff;
  --shadow-sm: 0 .125rem .4rem rgba(0, 0, 0, .07);
  --shadow-md: 0 .25rem .75rem rgba(0, 0, 0, .09);
  --shadow-lg: 0 .5rem 1.5rem rgba(0, 0, 0, .12);
  --r-sm: 6px;
  --r-md: 10px;
  --r-lg: 14px;
  --tr: all .22s ease;
}

/*.card-bpm-list>.card-header {
  background: linear-gradient(135deg, var(--primary-header) 0%, var(--primary-dark) 100%) !important
}

.card-bpm-list>.card-header .card-title {
  color: #fff !important
}

.card-bpm-list>.card-header .btn-tool {
  background: rgba(255, 255, 255, .18);
  border: 1px solid rgba(255, 255, 255, .25);
  color: #fff;
  font-size: 12px;
  padding: 3px 9px;
  border-radius: var(--r-sm);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  transition: var(--tr)
}

.card-bpm-list>.card-header .btn-tool:hover {
  background: rgba(255, 255, 255, .32)
}*/

/*.nav-tabs-bpm {
    background: var(--bgc);
    border-bottom: 3px solid var(--primary);
    padding: 0 4px;
    display: flex;
    gap: 2px;
    overflow-x: auto;
    margin-bottom: 0
  }

  .nav-tab-bpm {
    padding: 8px 16px;
    font-size: 13px;
    cursor: pointer;
    border-radius: var(--r-sm) var(--r-sm) 0 0;
    border: 1px solid transparent;
    border-bottom: none;
    color: var(--gr600);
    position: relative;
    bottom: -3px;
    white-space: nowrap;
    transition: var(--tr);
    user-select: none
  }

  .nav-tab-bpm:hover {
    background: var(--primary-light);
    color: var(--primary)
  }

  .nav-tab-bpm.active {
    background: var(--primary);
    color: #fff;
    border-color: var(--primary);
    font-weight: 600
  }*/

/* -- LAYOUT -- */

.bpm-page-layout {
  display: grid;
  grid-template-columns: 1fr 360px;
  gap: 18px;
  align-items: start
}

.bpm-left {
  min-width: 0
}

.bpm-right {
  position: sticky;
  top: 12px
}

/* -- FILTER -- */

.bpm-filter-bar {
  display: flex;
  align-items: center;
  gap: 7px;
  flex-wrap: wrap;
  margin-bottom: 12px;
  padding: 8px 12px;
  background: var(--gr100);
  border-radius: var(--r-md);
  border: 1px solid var(--gr300)
}

.bpm-filter-lbl {
  font-size: 11px;
  font-weight: 700;
  color: var(--gr600);
  text-transform: uppercase;
  letter-spacing: .05em;
  white-space: nowrap
}

.bpm-filter-tag {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 10px;
  border-radius: 20px;
  font-size: 11px;
  font-weight: 600;
  background: var(--bgc);
  border: 1.5px solid var(--gr300);
  color: var(--gr600);
  cursor: pointer;
  transition: var(--tr);
  white-space: nowrap
}

.bpm-filter-tag:hover {
  border-color: var(--primary);
  color: var(--primary);
  background: var(--primary-light)
}

.bpm-filter-tag.active {
  background: var(--primary);
  border-color: var(--primary);
  color: #fff
}

.bpm-filter-search {
  flex: 1;
  min-width: 150px;
  max-width: 230px
}

.bpm-filter-item {
  min-width: 130px;
  max-width: 180px;
}

.bpm-filter-item .select2-container--default .select2-selection--single {
  height: 28px !important;
  min-height: 28px !important;
  border-radius: 20px !important;
  padding: 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  border-color: var(--gr300) !important;
}

.bpm-filter-item .select2-container--default .select2-selection--single .select2-selection__rendered {
  line-height: 1 !important;
  padding-left: 14px !important;
  padding-right: 25px !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  color: var(--gr600) !important;
  display: block !important;
  width: 100% !important;
  text-align: left !important;
}

.bpm-filter-item .select2-container--default .select2-selection--single .select2-selection__arrow {
  height: 26px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  right: 8px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

/* Pulsante Clear (X) per reset singolo filtro */
.bpm-filter-item .select2-selection__clear {
  position: absolute !important;
  right: 26px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  font-size: 14px !important;
  color: var(--gr500) !important;
  margin: 0 !important;
  z-index: 1;
}

.bpm-filter-item.active .select2-selection__clear {
  color: rgba(255, 255, 255, 0.8) !important;
}

.bpm-filter-item.active .select2-selection__clear:hover {
  color: #fff !important;
}

/* Stato attivo per i filtri */
.bpm-filter-item.active .select2-container--default .select2-selection--single {
  background-color: var(--primary) !important;
  border-color: var(--primary) !important;
}

.bpm-filter-item.active .select2-container--default .select2-selection--single .select2-selection__rendered {
  color: #fff !important;
}

.bpm-filter-item.active .select2-container--default .select2-selection--single .select2-selection__arrow b {
  border-color: #fff transparent transparent transparent !important;
}

.bpm-filter-search input {
  width: 100%;
  padding: 5px 10px;
  border: 1.5px solid var(--gr300);
  border-radius: 20px;
  font-size: 12px;
  color: var(--text);
  background: var(--bgc);
  transition: var(--tr)
}

.bpm-filter-search input:focus {
  border-color: var(--primary);
  outline: none;
  box-shadow: 0 0 0 3px rgba(230, 122, 46, .1)
}

.bpm-filter-count {
  font-size: 11px;
  color: var(--gr500);
  margin-left: auto;
  white-space: nowrap
}

/* -- LEGEND -- */

.bpm-legend {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 12px;
  padding: 7px 12px;
  background: var(--gr100);
  border-radius: var(--r-md);
  border: 1px solid var(--gr300);
  flex-wrap: wrap
}

.bpm-legend-title {
  font-size: 11px;
  font-weight: 700;
  color: var(--main-grey-800)
}

.bpm-legend-item {
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: 11px;
  color: var(--gr600)
}

.bpm-legend-ring {
  width: 14px;
  height: 14px
}

.bpm-legend-status {
  margin-left: 8px;
  font-size: 10px;
  font-weight: 700;
  color: var(--main-orange-color);
  background: var(--main-orange-100);
  padding: 2px 8px;
  border-radius: 10px;
  border: 1px solid var(--main-orange-700)
}

/* -- TREE -- */

.bpm-tree {
  font-size: 13px
}

.bpm-tree .bpm-spinner {
  text-align: center;
  padding: 20px;
  color: var(--main-grey-500);
}

.bpm-node {
  margin-bottom: 2px
}

.bpm-node.dragging {
  opacity: .4
}

.bpm-node.drag-over>.bpm-row {
  background: var(--primary-light) !important;
  border-left-color: var(--primary) !important;
  outline: 2px dashed var(--primary-mid)
}

.bpm-row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 7px 12px;
  border-radius: var(--r-md);
  margin: 2px 0;
  border-left: 3px solid transparent;
  cursor: pointer;
  transition: var(--tr);
  user-select: none
}

.bpm-row:hover {
  background: #fdfdfd;
  border-left: 3px solid var(--primary);
  transform: translateX(4px);
  box-shadow: var(--shadow-sm)
}

.bpm-row.selected {
  background: var(--main-orange-light) !important;
  border-left: 3px solid var(--main-orange-color) !important;
  box-shadow: 0 2px 8px rgba(230, 122, 46, .15)
}

.bpm-row.lv0 {
  background: var(--main-blue-50);
  border-left: 4px solid var(--main-blue-color) !important;
  border-radius: var(--r-md);
  margin-bottom: 6px;
  border: 1px solid var(--main-blue-100);
  box-shadow: var(--shadow-sm);
}

.bpm-row.lv0:hover {
  background: var(--main-blue-150) !important;
  transform: translateX(2px)
}

.bpm-row.lv0.selected {
  background: linear-gradient(90deg, var(--main-blue-700) 0%, var(--main-blue-900) 100%) !important;
  border-left: 0px !important;
}

.bpm-row.lv0.selected > .bpm-name {
  color: #fff;
}

.bpm-row.lv0.selected > .bpm-toggle {
  color: #fff;
}

.bpm-macro-badge {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 10px;
  font-size: 10px;
  font-weight: 700;
  background: var(--main-blue-100);
  color: var(--main-blue-700);
  border: 1px solid var(--main-blue-200);
  margin-left: 8px;
  vertical-align: middle
}

.bpm-row.lv1 {
  background: var(--gr100);
  border-left: 3px solid transparent;
  color: #000;
}

.bpm-row.lv1:hover {
  background: #fdf6ef;
  border-left: 3px solid var(--primary)
}

.bpm-row.lv1.selected {
  background: var(--primary-light) !important
}

.bpm-toggle {
  width: 18px;
  height: 18px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--gr500);
  font-size: 9px;
  flex-shrink: 0;
}

.bpm-toggle.lv0 {
  color: var(--main-blue-600);
}

.bpm-toggle.lv1 {
  color: rgba(var(--main-blue-rgb), .8);
}

.bpm-code {
  font-size: 10px;
  font-weight: 700;
  font-family: 'Courier New', monospace;
  min-width: 52px;
  flex-shrink: 0;
}

.bpm-code.lv0 {
  color: var(--main-orange-600)
}

.bpm-code.lv1 {
  color: var(--main-blue-600)
}

.bpm-code.lv2 {
  color: var(--main-cyan-600)
}

.bpm-code.lv3 {
  color: var(--main-green-600)
}

.bpm-code-icon {
  font-size: 14px;
  flex-shrink: 0;
  color: var(--main-orange-600)
}

.bpm-code-icon.lv0 {
  color: var(--main-orange-600)
}

.bpm-code-icon.lv1 {
  color: var(--main-blue-600);
  font-size: 13px;
  flex-shrink: 0;
}

.bpm-code-icon.lv2 {
  color: var(--main-cyan-600);
  font-size: 12px;
  flex-shrink: 0;
}

.bpm-code-icon.lv3 {
  color: var(--main-green-600);
  font-size: 11px;
  flex-shrink: 0;
}

.bpm-name {
  flex: 1;
  min-width: 0;
  line-height: 1.3;
  font-size: 14px;
  font-weight: bold;
}

.bpm-name.lv0 {
  color: var(--main-blue-color);
}

.bpm-name.lv1 {
  color: var(--main-blue-600);
}

.bpm-name.lv2 {
  color: var(--main-cyan-color)
}

.bpm-name.lv3 {
  color: var(--main-green-color)
}

.bpm-meta {
  display: flex;
  align-items: center;
  gap: 5px;
  flex-shrink: 0
}

.bpm-children {
  margin-left: 28px;
  padding-left: 12px;
  border-left: 2px dashed var(--gr300);
  margin-top: 2px;
  margin-bottom: 2px
}

.bpm-children.hidden {
  display: none
}

.drag-handle {
  color: var(--gr400);
  font-size: 11px;
  cursor: grab;
  flex-shrink: 0;
  padding: 0 2px;
  opacity: 0;
  transition: opacity .15s
}

.bpm-row:hover .drag-handle {
  opacity: 1
}

/*----*/

.bpm-add-macroproc-btn,
.bpm-add-proc-btn {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 5px 10px;
  color: var(--main-orange-color);
  font-size: 12px;
  cursor: pointer;
  border: 1.5px dashed var(--main-orange-400);
  border-radius: var(--r-sm);
  margin-top: 5px;
  background: transparent;
  transition: var(--tr);
  font-weight: 600;
}

.bpm-add-proc-btn {
  margin-bottom: 5px;
}

.bpm-add-macroproc-btn .fa-plus,
.bpm-add-proc-btn .fa-plus {
  font-size: 10px;
  color:var(--main-orange-color)
}

.bpm-add-macroproc-btn:hover,
.bpm-add-proc-btn:hover {
  background: var(--main-orange-200);
  border-color: var(--main-orange-color)
}

.ring-row {
  display: flex;
  gap: 5px;
  align-items: center
}

.ring-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px
}

.ring-lbl {
  font-size: 8px;
  color: var(--gr500);
  font-weight: 600;
  letter-spacing: .04em;
  text-transform: uppercase
}

.ring-svg {
  width: 22px;
  height: 22px
}

/* -- BUTTON -- */

/* .btn-bpm {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 10px;
  border-radius: 20px;
  border: 1.5px solid var(--primary);
  background: var(--bgc);
  color: var(--primary);
  font-size: 11px;
  font-weight: 700;
  cursor: pointer;
  transition: var(--tr);
  white-space: nowrap
}

.btn-bpm:hover {
  background: var(--primary);
  color: #fff;
  box-shadow: 0 2px 8px rgba(230, 122, 46, .35);
  transform: translateY(-1px)
}

.btn-bpm.primary {
  background: var(--primary);
  color: #fff;
  padding: 6px 16px;
  font-size: 13px;
  border-radius: var(--r-sm)
}

.btn-bpm.primary:hover {
  background: var(--primary-dark)
}

.btn-act {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: var(--r-sm);
  border: 1.5px solid var(--gr300);
  background: var(--bgc);
  color: var(--gr600);
  cursor: pointer;
  font-size: 11px;
  transition: var(--tr)
}

.btn-act:hover {
  background: var(--gr100);
  transform: scale(1.08)
}

.btn-act.danger {
  border-color: #ffc9c9;
  color: var(--danger)
}

.btn-act.danger:hover {
  background: #fff0f0
}

.btn-act.warning {
  border-color: #ffeaa0;
  color: #b7860b
}

.btn-act.warning:hover {
  background: #fffbf0
}

.bpm-badge {
  display: inline-block;
  padding: 3px 8px;
  border-radius: 20px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .02em
}

.bb-va {
  background: #d1e7dd;
  color: #0f5132;
  border: 1px solid #badbcc;
  border-radius: 4px;
  padding: 3px 8px;
  font-size: 11px;
  font-weight: 700;
  display: inline-block
}

.bb-nva {
  background: #f8d7da;
  color: #842029;
  border: 1px solid #f5c2c7;
  border-radius: 4px;
  padding: 3px 8px;
  font-size: 11px;
  font-weight: 700;
  display: inline-block
} */

/* -- DETAIL PANEL -- */

.bpm-detail-panel .card-body {
  padding: .7em;
}

.dp-title {
  font-size: 14px;
  font-weight: 700;
  margin-bottom: 3px;
  display: flex;
  align-items: center;
  gap: 7px
}

.dp-title span {
  flex: 1
}

.dp-sub {
  font-size: 11px;
  opacity: .85
}

.dp-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px 12px;
  font-size: 12px;
  margin-bottom: 12px
}

.dp-field .lbl {
  color: var(--gr600);
  font-size: 11px;
  font-weight: 600;
  margin-bottom: 2px;
  text-transform: uppercase;
  letter-spacing: .04em
}

.dp-field .val {
  color: var(--main-grey-500)
}

div:not(.dp-grid) > .dp-field .val {
  font-size: 10px;
}

.dp-divider {
  border: none;
  border-top: 1px solid var(--gr200);
  margin: 12px 0
}

.dp-field.bpm {
  font-size: 11px;
  font-weight: 700;
  color:var(--gr600);
  text-transform: uppercase;
  letter-spacing: .05em;
  margin-bottom: 6px
}

.dp-field.bpm.bpm-list {
  display: flex;
  align-items: center;
  justify-content: space-between
}

.dp-field.bpm-step {
  font-weight: 400;
  color: var(--gr500)
}

.flow-steps {
  display: flex;
  align-items: center;
  gap: 0;
  margin-top: 6px
}

.flow-step {
  flex: 1;
  text-align: center;
  padding: 6px 2px;
  border-radius: var(--r-sm);
  font-size: 10px;
  font-weight: 700;
  transition: var(--tr);
  cursor: default
}

.flow-step.done {
  background: #dcfce7;
  color: #166534
}

.flow-step.partial {
  background: #fef9c3;
  color: #854d0e
}

.flow-step.todo {
  background: var(--gr100);
  color: var(--gr500);
  border: 1px dashed var(--gr300)
}

.flow-step.current {
  background: var(--primary-light);
  color: var(--primary-dark);
  border: 1.5px solid var(--primary-mid)
}

.flow-arrow {
  color: var(--gr400);
  font-size: 10px;
  flex-shrink: 0;
  padding: 0 1px
}

.flow-num {
  font-size: 9px;
  opacity: .7;
  display: block;
  margin-bottom: 1px
}

.bpm-mod-list {
  display: flex;
  flex-direction: column;
  gap: 5px;
  margin-top: 6px
}

.bpm-mod-row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 10px;
  border-radius: var(--r-sm);
  border: 1.5px solid var(--gr200);
  background: var(--gr100);
  cursor: pointer;
  transition: var(--tr)
}

.bpm-mod-row:hover {
  border-color: var(--primary);
  background: var(--primary-light)
}

.bpm-mod-row.done {
  border-left: 3px solid var(--success);
  background: #f0fdf4
}

.bpm-mod-row.partial {
  border-left: 3px solid var(--warning);
  background: #fffbeb
}

.bpm-mod-row.todo {
  border-left: 3px solid var(--gr300)
}

.bpm-mod-row.current {
  border-left: 3px solid var(--primary);
  background: var(--primary-light);
  border-color: var(--primary-mid)
}

.bpm-mod-num {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 10px;
  font-weight: 700;
  flex-shrink: 0
}

.bpm-mod-num.done {
  background: var(--success);
  color: #fff
}

.bpm-mod-num.partial {
  background: var(--warning);
  color: #fff
}

.bpm-mod-num.todo {
  background: var(--gr300);
  color: var(--gr600)
}

.bpm-mod-num.current {
  background: var(--primary);
  color: #fff
}

.bpm-mod-name {
  flex: 1;
  font-size: 12px;
  font-weight: 600;
  color: var(--text)
}

.bpm-mod-desc {
  font-size: 10px;
  color: var(--gr600)
}

.bpm-mod-status {
  font-size: 10px;
  padding: 2px 7px;
  border-radius: 10px;
  white-space: nowrap;
  margin-left: auto!important;
}

.bpm-mod-status.done {
  background: var(--main-green-200);
  color: var(--main-green-color);
}

.bpm-mod-status.partial {
  background: var(--main-orange-200);
  color: var(--main-orange-color);
}

.bpm-mod-status.todo {
  background: var(--gr300);
  color: var(--gr600);
}

.bpm-mod-status i {
  font-size: 9px;
}

.bpm-form-control {
  width: 100%;
  padding: 7px 11px;
  border: 1.5px solid var(--gr300);
  border-radius: var(--r-sm);
  font-size: 13px;
  color: var(--text);
  background: var(--bgc);
  transition: var(--tr)
}

.bpm-form-control:focus {
  border-color: var(--primary);
  outline: none;
  box-shadow: 0 0 0 3px rgba(230, 122, 46, .12)
}

.threshold-hint {
  font-size: 11px;
  color: var(--warning);
  margin-top: 4px;
  display: none
}

.threshold-hint.show {
  display: block
}

/* -- MODAL -- */

.bpm-modal-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(30, 30, 40, .45);
  z-index: 2000;
  align-items: center;
  justify-content: center;
  backdrop-filter: blur(2px)
}

.bpm-modal-overlay.show {
  display: flex
}

.bpm-modal-dialog {
  background: var(--bgc);
  border-radius: var(--r-lg);
  width: 680px;
  max-width: 95vw;
  max-height: 92vh;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  box-shadow: var(--shadow-lg);
  animation: bpmModalIn .2s ease
}

.bpm-modal-dialog.xl {
  width: 900px
}

@keyframes bpmModalIn {
  from {
    opacity: 0;
    transform: scale(.96) translateY(8px)
  }

  to {
    opacity: 1;
    transform: scale(1) translateY(0)
  }
}

.bpm-modal-header {
  padding: 14px 18px;
  border-bottom: 1px solid var(--gr200);
  display: flex;
  align-items: center;
  justify-content: space-between
}

.bpm-modal-title {
  font-size: 15px;
  font-weight: 700;
  color: var(--gr800);
  display: flex;
  align-items: center;
  gap: 8px
}

.bpm-modal-close {
  background: none;
  border: none;
  font-size: 20px;
  color: var(--gr500);
  cursor: pointer;
  padding: 3px 7px;
  border-radius: var(--r-sm);
  transition: var(--tr);
  line-height: 1
}

.bpm-modal-close:hover {
  background: var(--gr100);
  color: var(--gr800)
}

.bpm-modal-body {
  padding: 18px;
  background: var(--gr100);
  overflow-y: auto;
  flex: 1
}

.bpm-modal-footer {
  padding: 12px 18px;
  border-top: 1px solid var(--gr200);
  background: var(--gr100);
  display: flex;
  justify-content: flex-end;
  gap: 8px
}

.bpm-row-form {
  display: flex;
  gap: 14px;
  margin-bottom: 14px
}

.bpm-row-form .col {
  flex: 1;
  min-width: 0
}

.bpm-row-form .col-4 {
  flex: 0 0 calc(33.33% - 10px);
  min-width: 0
}

.bpm-lbl {
  display: block;
  margin-bottom: 5px;
  font-size: 12px;
  font-weight: 600;
  color: var(--gr600);
  letter-spacing: .02em
}

.bpm-lbl i {
  margin-right: 4px;
  font-size: 11px
}
















































































/* ===== CSS VARIABLES ===== */
:root {
  --primary:       #e67a2e;
  --primary-light: #fff5eb;
  --primary-mid:   #f9c07a;
  --primary-dark:  #c05a1a;
  --primary-grad:  linear-gradient(135deg,#e8813a 0%,#c05a1a 100%);
  --success:       #27ae60;
  --success-bg:    #d1e7dd;
  --success-text:  #0f5132;
  --success-border:#badbcc;
  --warning:       #f39c12;
  --warning-bg:    #fef9c3;
  --warning-text:  #854d0e;
  --danger:        #e74c3c;
  --danger-bg:     #f8d7da;
  --danger-text:   #842029;
  --danger-border: #f5c2c7;
  --info:          #2980b9;
  --info-bg:       #cff4fc;
  --info-text:     #055160;
  --purple:        #6f42c1;
  --purple-bg:     #ede7f6;
  --purple-text:   #4a148c;
  --gray-50:       #f8fafc;
  --gray-100:      #f1f5f9;
  --gray-200:      #e2e8f0;
  --gray-300:      #cbd5e1;
  --gray-400:      #94a3b8;
  --gray-500:      #64748b;
  --gray-600:      #475569;
  --gray-700:      #334155;
  --gray-800:      #1e293b;
  --text:          #1e293b;
  --bg:            #f0f2f5;
  --card:          #ffffff;
  --shadow-sm:     0 1px 3px rgba(0,0,0,.07), 0 1px 2px rgba(0,0,0,.04);
  --shadow-md:     0 4px 12px rgba(0,0,0,.09);
  --shadow-lg:     0 8px 24px rgba(0,0,0,.12);
  --r-sm:          6px;
  --r-md:          10px;
  --r-lg:          14px;
  --t:             all .22s ease;
}

/* ===== BASE ===== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Segoe UI','Source Sans Pro',sans-serif;font-size:14px;background:var(--bg);color:var(--text)}
.wrapper{display:flex;flex-direction:column;min-height:100vh}

/* ===== HEADER ===== */
/* .content-header{background:var(--card);border-bottom:1px solid var(--gray-200);padding:11px 22px;box-shadow:var(--shadow-sm)}
.ch-row{display:flex;align-items:center;justify-content:space-between;gap:12px}
.content-header h1{font-size:15px;font-weight:700;color:var(--primary);display:flex;align-items:center;gap:8px;margin:0}
.bc-sep{color:var(--gray-300)}
.bc-link{color:var(--gray-500);font-weight:400;font-size:14px;cursor:pointer;transition:var(--t)}
.bc-link:hover{color:var(--primary);text-decoration:underline}
.header-actions{display:flex;gap:6px}
.btn-default{display:inline-flex;align-items:center;gap:6px;padding:5px 13px;border:1.5px solid var(--gray-200);border-radius:var(--r-sm);background:var(--card);color:var(--gray-500);font-size:13px;cursor:pointer;text-decoration:none;transition:var(--t)}
.btn-default:hover{background:var(--gray-100);border-color:var(--gray-300);color:var(--gray-700);box-shadow:var(--shadow-sm)} */

/* ===== STEPPER TAB BAR ===== */
.stepper-bar{background:var(--card);border-bottom:1px solid var(--gray-200);padding:0 22px;box-shadow:var(--shadow-sm)}
.stepper{display:flex;align-items:stretch;overflow-x:auto}
.stepper-item{display:flex;align-items:center;gap:0;position:relative;flex-shrink:0}
.stepper-btn{display:flex;align-items:center;gap:10px;padding:14px 20px;cursor:pointer;transition:var(--t);border-bottom:3px solid transparent;color:var(--gray-500);font-size:13px;white-space:nowrap;background:transparent;border-top:none;border-left:none;border-right:none}
.stepper-btn:hover{background:var(--primary-light);color:var(--primary)}
.stepper-btn.active{color:var(--primary);border-bottom:3px solid var(--primary);font-weight:700}
.step-circle{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0;transition:var(--t)}
.step-circle.done{background:var(--success);color:#fff}
.step-circle.partial{background:var(--warning);color:#fff}
.step-circle.todo{background:var(--gray-200);color:var(--gray-500)}
.step-circle.active-c{background:var(--primary);color:#fff;box-shadow:0 0 0 3px var(--primary-light)}
.step-label{display:flex;flex-direction:column}
.step-name{font-size:13px;font-weight:600;line-height:1.2}
.step-sub{font-size:10px;color:var(--gray-400);margin-top:1px}
.stepper-btn.active .step-sub{color:var(--primary-mid)}
/* Connettore tra step */
.step-connector{width:32px;height:2px;flex-shrink:0;position:relative;display:flex;align-items:center}
.step-connector-line{width:100%;height:2px;border-radius:1px;background:var(--gray-200);position:relative;overflow:hidden}
.step-connector-fill{position:absolute;left:0;top:0;height:2px;border-radius:1px;background:var(--success);transition:width .5s ease}

/* ===== CONTENT ===== */
.content{padding:18px 22px}
.tab-panel{display:none}
.tab-panel.active{display:block}

/* ===== CONTEXT BAR ===== */
.bpm-context-bar {
  background: #fff;
  border: none;
  border-radius: var(--r-lg);
  padding: 10px 16px;
  margin-bottom: 18px;
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  box-shadow: var(--shadow-sm)
}

.bpm-context-bar-label {
  font-size: 11px;
  font-weight: 700;
  color: var(--main-orange-color);
  text-transform: uppercase;
  letter-spacing: .05em;
  white-space: nowrap
}

.bpm-context-bar-icon {
  margin-right: 4px;
  color: var(--main-orange-color)
}

.bpm-context-selector {
  display: flex;
  align-items: center;
  gap: 8px;
  flex: 1;
  min-width: 0;
  flex-wrap: wrap
}

.bpm-context-chip {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 4px 11px;
  border-radius: 20px;
  font-size: 12px;
  font-weight: 600
}

.bpm-context-chip i {
  font-size: 10px;
}

.bpm-context-chip.chip-macroproc {
  background: var(--main-blue-100);
  color: var(--main-blue-color);
  border: 1px solid var(--main-blue-400)
}

.bpm-context-chip.chip-proc {
  background: var(--main-cyan-100);
  color: var(--main-cyan-color);
  border: 1px solid var(--main-cyan-400)
}

.bpm-context-chip.chip-sep {
  color: var(--main-grey-400);
  font-size: 16px
}

/* ===== CARD ===== */
/*
.card{border:none;border-radius:var(--r-lg);margin-bottom:16px;background:var(--card);box-shadow:var(--shadow-sm);transition:var(--t);overflow:hidden}
.card:hover{box-shadow:var(--shadow-md)}
.card-header{padding:10px 18px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid rgba(0,0,0,.06)}
.card-title{font-size:13px;font-weight:700;margin:0;display:flex;align-items:center;gap:8px}
.card-tools{display:flex;gap:6px;align-items:center}
.card-body{padding:16px 18px}
.card-footer{background:var(--gray-50);border-top:1px solid var(--gray-200);padding:10px 18px;display:flex;align-items:center;justify-content:flex-end;gap:8px}
*/

/* Varianti header */
/*
.card-orange .card-header{background:var(--primary-grad)}
.card-orange .card-title{color:#fff}
.card-orange .btn-tool{background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.25);color:#fff;font-size:12px;padding:3px 9px;border-radius:var(--r-sm);cursor:pointer;display:inline-flex;align-items:center;gap:4px;transition:var(--t)}
.card-orange .btn-tool:hover{background:rgba(255,255,255,.32)}
.card-teal .card-header{background:linear-gradient(135deg,#17a2b8,#0d7a8c)}
.card-teal .card-title{color:#fff}
.card-teal .btn-tool{background:rgba(255,255,255,.2);border:1px solid rgba(255,255,255,.3);color:#fff;padding:3px 9px;border-radius:var(--r-sm);font-size:12px;cursor:pointer;transition:var(--t)}
.card-teal .btn-tool:hover{background:rgba(255,255,255,.35)}
.card-green .card-header{background:linear-gradient(135deg,#27ae60,#1a8a49)}
.card-green .card-title{color:#fff}
.card-green .btn-tool{background:rgba(255,255,255,.2);border:1px solid rgba(255,255,255,.3);color:#fff;padding:3px 9px;border-radius:var(--r-sm);font-size:12px;cursor:pointer;transition:var(--t)}
.card-warning .card-header{background:linear-gradient(135deg,#f39c12,#d68910)}
.card-warning .card-title{color:#fff}
.card-warning .btn-tool{background:rgba(255,255,255,.2);border:1px solid rgba(255,255,255,.3);color:#fff;padding:3px 9px;border-radius:var(--r-sm);font-size:12px;cursor:pointer;transition:var(--t)}
.card-purple .card-header{background:linear-gradient(135deg,#6f42c1,#5a32a3)}
.card-purple .card-title{color:#fff}
.card-purple .btn-tool{background:rgba(255,255,255,.2);border:1px solid rgba(255,255,255,.3);color:#fff;padding:3px 9px;border-radius:var(--r-sm);font-size:12px;cursor:pointer;transition:var(--t)}
*/
/* ===== ACCORDION ===== */
.accordion-item{border:none;border-radius:var(--r-lg);margin-bottom:12px;background:var(--card);box-shadow:var(--shadow-sm);overflow:hidden}
.accordion-header{padding:12px 18px;display:flex;align-items:center;justify-content:space-between;cursor:pointer;transition:var(--t);border-bottom:1px solid transparent}
.accordion-header:hover{background:var(--gray-50)}
.accordion-header.open{border-bottom:1px solid var(--gray-200)}
.accordion-title{font-size:13px;font-weight:700;display:flex;align-items:center;gap:10px}
.accordion-meta{display:flex;align-items:center;gap:10px}
.accordion-progress{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--gray-500)}
.accordion-prog-bar{width:80px;height:5px;background:var(--gray-200);border-radius:3px;overflow:hidden}
.accordion-prog-fill{height:5px;border-radius:3px;background:var(--primary);transition:width .4s ease}
.accordion-chevron{color:var(--gray-400);font-size:11px;transition:transform .22s ease;flex-shrink:0}
.accordion-chevron.open{transform:rotate(180deg)}
.accordion-body{display:none;padding:16px 18px;border-top:1px solid var(--gray-100)}
.accordion-body.open{display:block}
/* Colori per stato accordion */
.accordion-item.done .accordion-header{border-left:4px solid var(--success)}
.accordion-item.partial .accordion-header{border-left:4px solid var(--warning)}
.accordion-item.todo .accordion-header{border-left:4px solid var(--gray-200)}

/* ===== BADGE VA / BVA / NVA ===== */
.badge-va {
  background: var(--main-green-100);
  color: var(--main-green-color);
  border: 1px solid var(--main-green-200);
  border-radius: 4px;
  padding: 3px 8px;
  font-size: 11px;
  font-weight: 700;
  display: inline-block
}

.badge-bva {
  background: var(--main-cyan-100);
  color: var(--main-cyan-color);
  border: 1px solid var(--main-cyan-200);
  border-radius: 4px;
  padding: 3px 8px;
  font-size: 11px;
  font-weight: 700;
  display: inline-block
}

.badge-nva {
  background: var(--main-red-100);
  color: var(--main-red-color);
  border: 1px solid var(--main-red-200);
  border-radius: 4px;
  padding: 3px 8px;
  font-size: 11px;
  font-weight: 700;
  display: inline-block
}
/* Badge generici */
/*.badge{display:inline-block;padding:3px 8px;border-radius:20px;font-size:11px;font-weight:700}
.badge-primary{background:#dbeafe;color:#1d4ed8}
.badge-info{background:var(--info-bg);color:var(--info-text)}
.badge-success{background:var(--success-bg);color:var(--success-text)}
.badge-warning{background:var(--warning-bg);color:var(--warning-text)}
.badge-danger{background:var(--danger-bg);color:var(--danger-text)}
.badge-secondary{background:var(--gray-100);color:var(--gray-600);border:1px solid var(--gray-200)}
.badge-orange{background:var(--primary-light);color:var(--primary-dark);border:1px solid var(--primary-mid)}*/

/* ===== QUICK FILTER BAR ===== */
.quick-filter{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-bottom:12px;padding:8px 12px;background:var(--gray-50);border-radius:var(--r-md);border:1px solid var(--gray-200)}
.qf-label{font-size:11px;font-weight:700;color:var(--gray-500);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}
.qf-btn{display:inline-flex;align-items:center;gap:4px;padding:4px 11px;border-radius:20px;font-size:11px;font-weight:600;border:1.5px solid var(--gray-200);background:var(--card);color:var(--gray-600);cursor:pointer;transition:var(--t)}
.qf-btn:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-light)}
.qf-btn.active{background:var(--primary);border-color:var(--primary);color:#fff}
.qf-btn.nva-btn.active{background:var(--danger);border-color:var(--danger);color:#fff}
.qf-btn.crit-btn.active{background:var(--warning);border-color:var(--warning);color:#212529}
.qf-search{flex:1;min-width:140px;max-width:220px}
.qf-search input{width:100%;padding:5px 10px;border:1.5px solid var(--gray-200);border-radius:20px;font-size:12px;transition:var(--t)}
.qf-search input:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px rgba(230,122,46,.1)}

/* ===== RACI TABLE — zebra + sticky header + inline edit ===== */
.raci-wrapper{overflow-x:auto;border-radius:var(--r-md);border:1px solid var(--gray-200)}
.raci-table{width:100%;border-collapse:collapse;font-size:13px}
.raci-table thead tr{position:sticky;top:0;z-index:10;background:var(--gray-50)}
.raci-table th{padding:10px 12px;text-align:center;font-weight:700;color:var(--gray-600);font-size:11px;text-transform:uppercase;letter-spacing:.05em;border-bottom:2px solid var(--gray-200);white-space:nowrap}
.raci-table th.act-col{text-align:left;min-width:220px}
.raci-table td{padding:10px 12px;text-align:center;vertical-align:middle;border-bottom:1px solid var(--gray-100)}
.raci-table td.act-cell{text-align:left;font-weight:500}
/* Zebra */
.raci-table tbody tr:nth-child(even){background:var(--gray-50)}
.raci-table tbody tr:hover{background:var(--primary-light)!important;transition:background .15s}
/* Inline RACI edit */
.raci-cell-wrap{display:flex;align-items:center;justify-content:center;gap:3px}
.raci-badge{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;font-size:11px;font-weight:700;cursor:pointer;transition:var(--t);border:1.5px solid transparent}
.raci-R{background:var(--success-bg);color:var(--success-text);border-color:var(--success-border)}
.raci-A{background:var(--warning-bg);color:var(--warning-text);border-color:#fdd663}
.raci-AR{background:linear-gradient(135deg,var(--warning-bg) 0%,var(--success-bg) 100%);color:var(--warning-text);border-color:#fdd663;font-size:10px;letter-spacing:-0.5px}
.raci-C{background:var(--info-bg);color:var(--info-text);border-color:#b8e4f0}
.raci-I{background:var(--gray-100);color:var(--gray-600);border-color:var(--gray-300)}
.raci-empty{background:var(--gray-50);color:var(--gray-300);border-color:var(--gray-200);font-size:14px}
.raci-badge:hover{transform:scale(1.15);box-shadow:var(--shadow-sm)}
/* Dropdown RACI inline */
.raci-dropdown{position:relative;display:inline-block}
.raci-dropdown-menu{display:none;position:absolute;top:110%;left:50%;transform:translateX(-50%);background:var(--card);border:1px solid var(--gray-200);border-radius:var(--r-md);box-shadow:var(--shadow-lg);z-index:100;padding:6px;min-width:140px}
.raci-dropdown-menu.open{display:block;animation:fadeIn .15s ease}
@keyframes fadeIn{from{opacity:0;transform:translateX(-50%) translateY(-4px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}
.raci-opt{display:flex;align-items:center;gap:8px;padding:5px 8px;border-radius:var(--r-sm);cursor:pointer;transition:var(--t);font-size:12px}
.raci-opt:hover{background:var(--gray-100)}
.raci-opt-dot{width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;flex-shrink:0}

/* ===== ASSET CHIP ===== */
.asset-chips{display:flex;flex-wrap:wrap;gap:5px}
.asset-chip{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:20px;font-size:11px;font-weight:600;cursor:pointer;transition:var(--t);position:relative}
.asset-chip:hover{box-shadow:var(--shadow-sm)}
.asset-chip.persona{background:#ede7f6;color:var(--purple-text);border:1px solid #d1c4e9}
.asset-chip.sistema{background:var(--info-bg);color:var(--info-text);border:1px solid #b8e4f0}
.asset-chip.documento{background:var(--warning-bg);color:var(--warning-text);border:1px solid #fdd663}
/* Tooltip asset */
.asset-tooltip{display:none;position:absolute;bottom:110%;left:50%;transform:translateX(-50%);background:var(--gray-800);color:#fff;font-size:11px;padding:6px 10px;border-radius:var(--r-sm);white-space:nowrap;z-index:200;pointer-events:none;box-shadow:var(--shadow-lg)}
.asset-chip:hover .asset-tooltip{display:block;animation:fadeInTt .15s ease}
@keyframes fadeInTt{from{opacity:0;transform:translateX(-50%) translateY(3px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}

/* ===== COMPLETAMENTO HEADER ===== */
.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.section-title-row{font-size:12px;font-weight:700;color:var(--gray-600);text-transform:uppercase;letter-spacing:.06em;display:flex;align-items:center;gap:8px}
.completion-badge{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--gray-500)}
.mini-prog{width:60px;height:5px;background:var(--gray-200);border-radius:3px;overflow:hidden}
.mini-prog-fill{height:5px;border-radius:3px;background:var(--primary);transition:width .4s}

/* ===== ASIS CHECKLIST VALIDAZIONE ===== */
.asis-checklist-body {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0;
    padding: 0;
}

.asis-checklist-row {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 16px;
    border-bottom: 1px solid var(--gray-100);
    font-size: 13px;
    transition: var(--t);
    background: #fff;
}

.asis-checklist-row:hover {
    background: var(--gray-50);
}

.asis-checklist-icon {
    width: 20px;
    height: 20px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 10px;
    flex-shrink: 0;
    cursor: pointer;
    transition: var(--t);
}

.asis-checklist-icon:hover {
    transform: scale(1.1);
}

.asis-checklist-icon.ok { background: var(--main-green-100); color: var(--main-green-color); }
.asis-checklist-icon.warn { background: var(--main-yellow-100); color: var(--main-yellow-color); }
.asis-checklist-icon.err { background: var(--main-red-100); color: var(--main-red-color); }

.asis-checklist-text {
    flex: 1;
    color: var(--main-grey-700);
    cursor: pointer;
    font-weight: 500;
}

.asis-checklist-actions {
    display: flex;
    gap: 10px;
    opacity: 0;
    transition: var(--t);
    align-items: center;
}

.asis-checklist-row:hover .asis-checklist-actions {
    opacity: 1;
}

.asis-checklist-actions i {
    cursor: pointer;
    font-size: 12px;
}

.asis-checklist-actions .fa-edit { color: var(--main-blue-color); }
.asis-checklist-actions .fa-trash-alt { color: var(--main-red-color); }

/* ===== ASIS ASSET REPOSITORY ===== */
.asis-asset-type-badge {
    padding: 3px 10px;
    border-radius: 20px;
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    display: inline-block;
}
.asis-asset-type-badge.persona { background: var(--main-blue-100); color: var(--main-blue-color); border: 1px solid var(--main-blue-300); }
.asis-asset-type-badge.sistema { background: var(--main-orange-100); color: var(--main-orange-color); border: 1px solid var(--main-orange-300); }
.asis-asset-type-badge.documento { background: var(--main-green-100); color: var(--main-green-color); border: 1px solid var(--main-green-300); }
.asis-asset-type-badge.strumento { background: var(--main-red-100); color: var(--main-red-800); border: 1px solid var(--main-red-300); }

.asis-asset-chip {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 4px 10px;
    background: var(--main-cyan-50);
    border: 1px solid var(--main-cyan-200);
    border-radius: var(--r-md);
    font-size: 11px;
    font-weight: 600;
    color: var(--main-cyan-700);
    margin-right: 4px;
    margin-bottom: 4px;
}
.asis-asset-chip i {
  font-size: 10px;
  color: var(--main-cyan-400);
}

.asis-asset-activity-badge {
    font-family: monospace;
    background: var(--main-blue-50);
    color: var(--main-blue-color);
    padding: 1px 5px;
    border-radius: 3px;
    font-size: 9.5px;
    font-weight: 700;
    margin-right: 2px;
    border: 1px solid var(--main-blue-200);
    display: inline-block;
}

/* ===== COST SIMULATOR ===== */
.sim-row{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.sim-label{font-size:12px;color:var(--gray-600);flex:1;min-width:0}
.sim-input{width:80px;padding:5px 8px;border:1.5px solid var(--gray-200);border-radius:var(--r-sm);font-size:12px;text-align:right;transition:var(--t)}
.sim-input:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 2px rgba(230,122,46,.1)}
.sim-unit{font-size:11px;color:var(--gray-400);white-space:nowrap}
.cost-result{background:var(--gray-50);border:1px solid var(--gray-200);border-radius:var(--r-md);padding:12px;margin-top:10px}
.cost-compare{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:8px}
.cost-box{text-align:center;padding:10px;border-radius:var(--r-sm)}
.cost-box.asis{background:var(--danger-bg);border:1px solid var(--danger-border)}
.cost-box.tobe{background:var(--success-bg);border:1px solid var(--success-border)}
.cost-num{font-size:18px;font-weight:700}
.cost-num.asis{color:var(--danger-text)}
.cost-num.tobe{color:var(--success-text)}
.cost-lbl{font-size:10px;color:var(--gray-500);margin-top:2px}
.cost-saving{text-align:center;font-size:13px;font-weight:700;color:var(--success-text);background:var(--success-bg);padding:6px;border-radius:var(--r-sm);border:1px solid var(--success-border)}

/* ===== KPI CARDS ===== */
.kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:16px}
.kpi-card{background:var(--card);border:none;border-radius:var(--r-lg);padding:14px 16px;box-shadow:var(--shadow-sm);border-left:4px solid var(--primary)}
.kpi-card.green{border-left-color:var(--success)}
.kpi-card.red{border-left-color:var(--danger)}
.kpi-card.blue{border-left-color:var(--info)}
.kpi-card.yellow{border-left-color:var(--warning)}
.kpi-num{font-size:26px;font-weight:700;color:var(--text);line-height:1}
.kpi-label{font-size:11px;color:var(--gray-500);margin-top:5px}
.kpi-trend{font-size:11px;margin-top:4px}
.kpi-trend.up{color:var(--success)}
.kpi-trend.down{color:var(--danger)}

/* ===== FORM ===== */
/*.row-form{display:flex;gap:14px;margin-bottom:14px}
.col{flex:1;min-width:0}
.col-3{flex:0 0 calc(25% - 10px);min-width:0}
.col-4{flex:0 0 calc(33.33% - 10px);min-width:0}
.col-8{flex:0 0 calc(66.66% - 7px);min-width:0}
.form-label{display:block;margin-bottom:5px;font-size:12px;font-weight:600;color:var(--gray-600);letter-spacing:.02em}
.form-label i{margin-right:4px;font-size:11px}
.form-control{width:100%;padding:7px 11px;border:1.5px solid var(--gray-200);border-radius:var(--r-sm);font-size:13px;color:var(--text);background:var(--card);transition:var(--t)}
.form-control:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px rgba(230,122,46,.1)}
textarea.form-control{resize:vertical}
.input-group{display:flex}
.input-group .form-control{border-radius:var(--r-sm) 0 0 var(--r-sm);flex:1}
.input-group-append{background:var(--gray-100);border:1.5px solid var(--gray-200);border-left:none;border-radius:0 var(--r-sm) var(--r-sm) 0;padding:0 11px;display:flex;align-items:center;color:var(--gray-500);font-size:13px}
.text-danger{color:var(--danger)!important}
.text-muted{color:var(--gray-500)!important}*/

/* ===== BUTTONS ===== */
.btn{display:inline-flex;align-items:center;gap:5px;padding:6px 14px;border-radius:var(--r-sm);border:1.5px solid transparent;font-size:13px;font-weight:600;cursor:pointer;transition:var(--t)}
.btn-sm{padding:4px 10px;font-size:12px}
.btn-xs{padding:2px 8px;font-size:11px}
.btn-success{background:var(--success);border-color:var(--success);color:#fff}
.btn-success:hover{background:#1a8a49;box-shadow:0 3px 8px rgba(39,174,96,.35);transform:translateY(-1px)}
.btn-primary{background:var(--info);border-color:var(--info);color:#fff}
.btn-warning{background:var(--warning);border-color:var(--warning);color:#212529}
.btn-orange{background:var(--primary);border-color:var(--primary);color:#fff}
.btn-orange:hover{background:var(--primary-dark);box-shadow:0 3px 8px rgba(230,122,46,.35);transform:translateY(-1px)}
.btn-outline{background:transparent;border-color:var(--gray-300);color:var(--gray-600)}
.btn-outline:hover{border-color:var(--gray-500);background:var(--gray-50)}
.btn-tool-dark{background:var(--gray-100);border:1.5px solid var(--gray-200);color:var(--gray-600);font-size:12px;padding:4px 10px;border-radius:var(--r-sm);cursor:pointer;display:inline-flex;align-items:center;gap:4px;transition:var(--t)}
.btn-tool-dark:hover{background:var(--gray-200)}
.btn-action{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:var(--r-sm);border:1.5px solid var(--gray-200);background:var(--card);color:var(--gray-500);cursor:pointer;font-size:11px;transition:var(--t)}
.btn-action:hover{background:var(--gray-100);transform:scale(1.08)}
.btn-action.danger{border-color:#ffc9c9;color:var(--danger)}
.btn-action.danger:hover{background:var(--danger-bg)}

/* ===== PROGRESS BAR ===== */
.progress{background:var(--gray-200);border-radius:4px;height:8px;overflow:hidden}
.progress-bar{height:8px;border-radius:4px;background:var(--primary);transition:width .4s}
.progress-bar.green{background:var(--success)}
.progress-bar.red{background:var(--danger)}
.progress-bar.blue{background:var(--info)}

/* ===== ALERT ===== */
.alert{padding:10px 14px;border-radius:var(--r-md);font-size:13px;margin-bottom:14px;display:flex;align-items:flex-start;gap:8px;box-shadow:var(--shadow-sm)}
.alert-warning{background:var(--warning-bg);border:1px solid #fdd663;color:var(--warning-text)}
.alert-info{background:var(--info-bg);border:1px solid #b8e4f0;color:var(--info-text)}
.alert-success{background:var(--success-bg);border:1px solid var(--success-border);color:var(--success-text)}
.alert-danger{background:var(--danger-bg);border:1px solid var(--danger-border);color:var(--danger-text)}

/* ===== LAYOUT ===== */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.two-col-wide{display:grid;grid-template-columns:2fr 1fr;gap:16px}
.three-col{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}

/* ===== BPMN ===== */
.bpmn-canvas{background:var(--gray-50);border:1px solid var(--gray-200);border-radius:var(--r-md);overflow:hidden}
.bpmn-toolbar{background:var(--card);border-bottom:1px solid var(--gray-200);padding:7px 12px;display:flex;align-items:center;gap:5px;flex-wrap:wrap}
.bpmn-tool-btn{padding:4px 9px;border:1.5px solid var(--gray-200);border-radius:var(--r-sm);background:var(--card);font-size:11px;color:var(--gray-600);cursor:pointer;display:inline-flex;align-items:center;gap:4px;transition:var(--t)}
.bpmn-tool-btn:hover{background:var(--gray-100);border-color:var(--gray-400)}
.bpmn-tool-btn.active{background:var(--primary-light);border-color:var(--primary);color:var(--primary)}
.bpmn-sep{width:1px;height:20px;background:var(--gray-200);margin:0 3px}

/* ===== PROCESS DIAGRAM (AS-IS / TO-BE) ===== */

/* -- ASIS -- */
.tg-canvas{overflow-x:auto;position:relative}
.tg-canvas-inner{min-width:fit-content;position:relative}
.tg-flow-svg{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:5;overflow:visible}
.tg-flow-svg path,.tg-flow-svg line{fill:none}
.tg-flow-label{font-size:10px;font-family:'Segoe UI',sans-serif;font-style:italic;background:#fff}

/* Header fasi (default 8 colonne, override per 5) */
.tg-phase-row{display:grid;grid-template-columns:repeat(8,1fr);gap:14px;margin-bottom:8px;padding-left:140px}
.tg-phase-row.tg-phase-row-5{grid-template-columns:repeat(5,1fr);gap:22px}
.tg-phase-lbl{font-size:10px;font-weight:700;color:var(--main-orange-800);text-transform:uppercase;letter-spacing:.04em;text-align:center;padding:8px 6px;background:var(--main-orange-100);border:1px solid var(--main-orange-400);border-radius:var(--r-sm)}

.tobe-diagram .tg-phase-lbl { color: #1F7A4D; background: #e1f0e8; border-color: #1F7A4D; }

.tg-phase-row-5 .tg-phase-lbl{padding:9px 8px;font-size:10.5px}
.tg-phase-code{display:block;font-family:monospace;background:var(--main-orange-color);color:#fff;padding:2px 6px;border-radius:3px;font-size:9.5px;margin-bottom:4px;letter-spacing:0;font-weight:700;display:inline-block}

.tobe-diagram .tg-phase-code { background: #1F7A4D; }

/* Swimlane (label sinistra) */
.tg-swimlane {
    display: grid;
    grid-template-columns: 140px 1fr;
    gap: 0;
    border-bottom: 1px dashed var(--main-grey-200);
    /* min-height: 170px; */
    position: relative;
}

.tg-swimlane:last-child {
    border-bottom: none;
}

.tg-lane-label {
    background: var(--main-blue-50);
    border-right: 2px solid var(--main-blue-200);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 12px 8px;
    font-size: 10.5px;
    font-weight: 700;
    color: var(--main-blue-900);
    text-transform: uppercase;
    letter-spacing: .05em;
    text-align: center;
    line-height: 1.35;
    transition: var(--t);
}

.tobe-diagram .tg-lane-label { background: #f0f7f2; border-right-color: #c8e0d2; color: #1F7A4D; }

/* Lane speciale per attività non assegnate */

/* Lane speciale per attività non assegnate */
.tg-lane-label.lane-na {
    background: var(--main-grey-50);
    color: var(--main-grey-500);
    border-right: 2px dashed var(--main-grey-300);
}

.tg-lane-content {
    padding: 18px 10px;
    display: grid;
    /* Grid-template-columns impostato via JS */
    gap: 14px;
    align-items: start;
    position: relative;
}

/* Cella di una swimlane (può contenere più nodi) */
.tg-cell {
    display: flex;
    flex-direction: column;
    gap: 16px;
    min-height: 1px;
}

/* Nodo BPMN */
.tg-node {
    background: #fff;
    border: 1.2px solid var(--main-grey-200);
    border-radius: var(--r-sm);
    padding: 14px 0px;
    font-size: 11px;
    line-height: 1.4;
    text-align: center;
    min-height: 60px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    position: relative;
    cursor: default;
    transition: var(--t);
    z-index: 2;
    box-shadow: 0 2px 4px rgba(0,0,0,0.04);
}

.tg-node:hover {
    box-shadow: var(--shadow-md);
    transform: translateY(-2px);
    z-index: 3;
}

/* Badge codice interno al nodo */
.tg-node-badge {
    position: absolute;
    top: -9px;
    left: 10px;
    color: #fff;
    padding: 1px 9px;
    border-radius: 12px;
    font-size: 9.5px;
    font-weight: 800;
    font-family: 'Segoe UI', monospace;
    box-shadow: 0 2px 4px rgba(0,0,0,0.15);
    z-index: 5;
    letter-spacing: 0.02em;
}

/* Schemi colori alternati (4 varianti) */
.tg-node.c1 { border-top: 3.5px solid var(--main-blue-color); background: var(--main-blue-50); color: var(--main-blue-900); }
.tg-node.c1 .tg-node-badge { background: var(--main-blue-color); }

.tg-node.c2 { border-top: 3.5px solid var(--main-orange-color); background: var(--main-orange-50); color: var(--main-orange-900); }
.tg-node.c2 .tg-node-badge { background: var(--main-orange-color); }

.tg-node.c3 { border-top: 3.5px solid var(--main-green-color); background: var(--main-green-50); color: var(--main-green-900); }
.tg-node.c3 .tg-node-badge { background: var(--main-green-color); }

.tg-node.c4 { border-top: 3.5px solid var(--main-red-color); background: var(--main-red-50); color: var(--main-red-900); }
.tg-node.c4 .tg-node-badge { background: var(--main-red-color); }

/* Nodo gateway/decisione */
.tg-node.tg-decision {
    background: var(--main-yellow-50);
    border: 2px solid var(--main-yellow-color);
    border-top-width: 4px;
    color: var(--main-yellow-800);
    border-radius: var(--r-sm);
}

.tg-node.tg-decision::before {
    content: "◆ GATEWAY";
    display: block;
    position: absolute;
    top: -11px;
    left: 50%;
    transform: translateX(-50%);
    background: var(--main-yellow-color);
    color: #fff;
    font-size: 8.5px;
    font-weight: 800;
    padding: 1px 10px;
    border-radius: 3px;
    letter-spacing: .06em;
}
.tg-node.tg-event-start{background:#1A1A1A;border-color:#1A1A1A;color:#fff;border-radius:50%;min-height:60px;width:60px;justify-self:center;font-weight:700}
.tg-node.tg-event-end{background:#fff;border:3px solid #1A1A1A;color:#1A1A1A;border-radius:50%;min-height:60px;width:60px;justify-self:center;font-weight:700}
.tg-node-code{display:block;font-family:monospace;font-size:9px;font-weight:700;opacity:.65;margin-bottom:3px;letter-spacing:0}
.tg-node-title{font-weight:600;font-size:11px;margin-bottom:2px;line-height:1.25}
.tg-node-sub{font-size:10px;color:inherit;opacity:.85;line-height:1.3}
.tg-node-warn{font-size:9.5px;color:#A31621;font-style:italic;margin-top:2px;font-weight:600}

.tg-node-tag {
  display: inline-block;
  color: #fff;
  font-size: 9px;
  font-weight: 700;
  padding: 2px 5px;
  border-radius: 3px;
  margin: 3px 6px 0 6px;
  font-family: monospace;
  letter-spacing: .03em
}

.tg-node-tag.tg-gap-tag {
  background: var(--main-red-color)
}

.tg-node-tag.tg-improve-tag {
  background: var(--main-green-color)
}

/* Connettori orizzontali tra fasi */
.tg-flow-arrow{position:absolute;height:2px;background:var(--gray-400);top:50%;transform:translateY(-50%)}
.tg-flow-arrow::after{content:"";position:absolute;right:-1px;top:-4px;border-left:8px solid var(--gray-400);border-top:5px solid transparent;border-bottom:5px solid transparent}
.tg-flow-arrow.flow-critical{background:#A31621}
.tg-flow-arrow.flow-critical::after{border-left-color:#A31621}
.tg-flow-arrow.flow-new{background:#1F7A4D;height:2.5px}
.tg-flow-arrow.flow-new::after{border-left-color:#1F7A4D}

/* === EDIT MODE: drag nodi + pannello frecce === */
.tg-canvas[data-editing="true"]{background:repeating-linear-gradient(45deg,#fff,#fff 8px,#f9fafb 8px,#f9fafb 16px);outline:2px dashed var(--primary);outline-offset:-2px}
.tg-canvas[data-editing="true"] .tg-node{cursor:move;outline:1.5px dashed transparent;transition:outline-color .15s}
.tg-canvas[data-editing="true"] .tg-node:hover{outline-color:var(--primary);box-shadow:0 0 0 3px rgba(255,140,30,.15)}
.tg-canvas[data-editing="true"] .tg-node.tg-dragging{opacity:.7;outline-color:var(--primary);outline-width:2.5px;z-index:100}
.tg-canvas[data-editing="true"] .tg-node[data-positioned="true"]{outline-color:#1F7A4D;outline-style:solid;outline-width:1.5px}
.tg-canvas[data-editing="true"] .tg-node.tg-target-candidate{outline:2.5px solid #1F7A4D !important;animation:tg-pulse .8s infinite alternate;cursor:crosshair !important}
@keyframes tg-pulse{from{box-shadow:0 0 0 3px rgba(31,122,77,.2)}to{box-shadow:0 0 0 8px rgba(31,122,77,.05)}}
.tg-canvas[data-editing="true"] .tg-node.tg-source-pending{outline:2.5px solid var(--primary) !important;cursor:crosshair !important;background:#fff8f0}

/* SVG path interattivo: hover + selezione */
.tg-canvas[data-editing="true"] .tg-flow-svg path[data-edge-idx]{cursor:pointer;pointer-events:stroke;stroke-width:14;stroke:transparent;fill:none}
.tg-canvas[data-editing="true"] .tg-flow-svg .tg-edge-hover{stroke:var(--primary) !important;stroke-width:3 !important;opacity:.7}
.tg-canvas[data-editing="true"] .tg-flow-svg .tg-edge-selected{stroke:var(--primary) !important;stroke-width:3 !important}

/* Handle interattivi sui lati dei nodi (visibili quando una freccia è selezionata) */
.tg-side-handle{position:absolute;width:18px;height:18px;background:#fff;border:2.5px solid var(--primary);border-radius:50%;cursor:pointer;z-index:60;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;color:var(--primary);box-shadow:0 2px 5px rgba(0,0,0,.2);user-select:none;transition:transform .15s,background .15s}
.tg-side-handle:hover{transform:scale(1.25);background:var(--primary);color:#fff}
.tg-side-handle.tg-handle-active{background:var(--primary);color:#fff;transform:scale(1.2)}

/* Mini-toolbar che appare sopra una freccia selezionata */
.tg-edge-toolbar{position:absolute;background:#fff;border:1.5px solid var(--primary);border-radius:var(--r-md);box-shadow:0 4px 12px rgba(0,0,0,.15);padding:5px;display:flex;gap:4px;align-items:center;z-index:70;font-size:11px}
.tg-edge-toolbar input{font-size:11px;padding:3px 6px;border:1px solid var(--gray-200);border-radius:3px;width:140px}
.tg-edge-toolbar select{font-size:11px;padding:3px 5px;border:1px solid var(--gray-200);border-radius:3px}
.tg-edge-toolbar button{padding:4px 7px;font-size:10.5px;border:1px solid var(--gray-200);background:#fff;border-radius:3px;cursor:pointer;color:var(--gray-700)}
.tg-edge-toolbar button:hover{background:var(--gray-50)}
.tg-edge-toolbar button.tg-tb-del{background:var(--danger);color:#fff;border-color:var(--danger)}
.tg-edge-toolbar button.tg-tb-del:hover{background:#8a1219}
.tg-edge-toolbar .tg-tb-info{font-family:monospace;font-size:10px;color:var(--gray-500);padding:0 6px;border-right:1px solid var(--gray-200)}

/* Pannello edit frecce sotto il diagramma */
.tg-edit-panel{margin-top:14px;background:linear-gradient(135deg,#fff5eb 0%,#fff 100%);border:1.5px solid var(--primary-mid);border-radius:var(--r-md);padding:14px 16px;display:none}
.tg-canvas[data-editing="true"] ~ .tg-edit-panel{display:block}
.tg-edit-panel-title{font-size:12.5px;font-weight:700;color:var(--primary-dark);text-transform:uppercase;letter-spacing:.05em;margin-bottom:10px;display:flex;align-items:center;gap:6px}
.tg-edit-panel-title i{color:var(--primary)}
.tg-edit-help{background:var(--info-bg);border-left:3px solid var(--info);padding:8px 12px;font-size:11px;color:var(--info-text);margin-bottom:10px;line-height:1.55;border-radius:0 var(--r-sm) var(--r-sm) 0}
.tg-edit-help strong{color:var(--info-text);font-weight:700}
.tg-edit-help kbd{background:#fff;border:1px solid var(--gray-300);border-radius:3px;padding:1px 5px;font-family:monospace;font-size:10px;box-shadow:0 1px 0 var(--gray-300);color:var(--gray-700)}

.tg-edit-panel-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:6px}
.tg-edit-panel-actions button{padding:7px 13px;font-size:11.5px;border-radius:var(--r-sm);border:1.5px solid;cursor:pointer;font-weight:600;display:inline-flex;align-items:center;gap:5px;transition:var(--t)}
.tg-btn-add{background:var(--success);color:#fff;border-color:var(--success)}
.tg-btn-add:hover{background:#0e3d1f}
.tg-btn-add.active{background:var(--primary);border-color:var(--primary);animation:tg-pulse-btn 1s infinite alternate}
@keyframes tg-pulse-btn{from{box-shadow:0 0 0 0 rgba(255,140,30,.3)}to{box-shadow:0 0 0 6px rgba(255,140,30,0)}}
.tg-btn-reset{background:#fff;color:var(--gray-700);border-color:var(--gray-300)}
.tg-btn-reset:hover{background:var(--gray-100)}
.tg-btn-export{background:var(--info);color:#fff;border-color:var(--info)}
.tg-btn-export:hover{background:#1e6a93}

/* Indicatore "modalità aggiungi freccia" */
.tg-add-edge-banner{background:var(--primary);color:#fff;padding:8px 14px;border-radius:var(--r-sm);font-size:12px;font-weight:600;margin-bottom:10px;display:none;align-items:center;gap:8px}
.tg-add-edge-banner.active{display:flex}
.tg-add-edge-banner i{font-size:14px}
.tg-add-edge-banner button{margin-left:auto;background:rgba(255,255,255,.2);border:1px solid rgba(255,255,255,.4);color:#fff;padding:3px 10px;border-radius:3px;cursor:pointer;font-size:11px}
.tg-add-edge-banner button:hover{background:rgba(255,255,255,.3)}

/* Editor toolbar diagramma */
.tg-toolbar{background:var(--gray-50);border:1px solid var(--gray-200);border-bottom:none;border-radius:var(--r-md) var(--r-md) 0 0;padding:8px 12px;display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:11px}
.tg-toolbar-info{color:var(--gray-500);display:flex;align-items:center;gap:6px}
.tg-toolbar-info i{color:var(--primary)}
.tg-toolbar-actions{margin-left:auto;display:flex;gap:6px}
.tg-edit-btn{padding:4px 10px;border:1px solid var(--gray-300);background:#fff;border-radius:var(--r-sm);cursor:pointer;font-size:11px;color:var(--gray-600);display:inline-flex;align-items:center;gap:5px;transition:var(--t)}
.tg-edit-btn:hover{background:var(--gray-100)}
.tg-edit-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}

/* Legenda diagramma */
.tg-legend{display:flex;gap:14px;flex-wrap:wrap;padding:10px 14px;background:var(--gray-50);border:1px solid var(--gray-200);border-top:none;border-radius:0 0 var(--r-md) var(--r-md);font-size:10px;align-items:center}
.tg-legend-item{display:inline-flex;align-items:center;gap:5px;color:var(--gray-600)}
.tg-legend-swatch{width:18px;height:12px;border-radius:2px;display:inline-block}

/* Critical points strip */
.tg-critical-strip{margin-top:14px;background:#FDE8EA;border:1.5px solid #A31621;border-radius:var(--r-md);padding:12px 16px;font-size:12px;color:#5A0F18;line-height:1.55}
.tg-critical-strip strong{color:#A31621;display:block;margin-bottom:4px;font-size:12px;text-transform:uppercase;letter-spacing:.05em}
.tg-evolution-strip{margin-top:14px;background:#E1F0E8;border:1.5px solid #1F7A4D;border-radius:var(--r-md);padding:12px 16px;font-size:12px;color:#0F4A2D;line-height:1.55}
.tg-evolution-strip strong{color:#1F7A4D;display:block;margin-bottom:4px;font-size:12px;text-transform:uppercase;letter-spacing:.05em}

/* ===== TREE STRUCTURE ===== */

/* -- ASIS & TO-BE TREE -- */
.asis-tree .tree-node,
.tobe-tree .tree-node {
  margin-bottom: 2px
}

.asis-tree .tree-row,
.tobe-tree .tree-row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 10px;
  cursor: pointer;
  border-radius: var(--r-sm);
  transition: var(--t);
  user-select: none
}

.asis-tree .tree-row-sub,
.tobe-tree .tree-row-sub {
  padding: 11px 12px;
  background: linear-gradient(135deg, var(--main-orange-50) 0%, var(--main-orange-100) 100%);
  border: 1.5px solid var(--main-orange-color)
}

.tobe-tree .tree-row-sub {
  background: linear-gradient(135deg, #e1f0e8 0%, #c8e0d2 100%);
  border-color: #1F7A4D
}

.asis-tree .tree-row-sub:hover,
.tobe-tree .tree-row-sub:hover {
  box-shadow: var(--shadow-sm)
}

.asis-tree .tree-row-act,
.tobe-tree .tree-row-act {
  padding: 5px 10px;
  background: transparent;
  margin: 2px 0 2px 28px;
  cursor: default;
  border-left: 2px solid var(--main-grey-300)
}

.asis-tree .tree-row-act:hover,
.tobe-tree .tree-row-act:hover {
  background: var(--main-grey-100);
  border-left-color: var(--main-cyan-color)
}

.asis-tree .tree-caret,
.tobe-tree .tree-caret {
  font-size: 14px;
  color: var(--main-grey-600);
  width: 14px;
  text-align: center;
  transition: transform .2s
}

.asis-tree .tree-caret.open,
.tobe-tree .tree-caret.open {
  transform: rotate(0deg)
}

.asis-tree .tree-row-sub .tree-caret,
.tobe-tree .tree-row-sub .tree-caret {
  color: var(--main-orange-color);
  font-size: 16px
}

.tobe-tree .tree-row-sub .tree-caret {
  color: #1F7A4D
}

.asis-tree .tree-bullet,
.tobe-tree .tree-bullet {
  font-size: 5px;
  color: var(--main-grey-300);
  width: 14px;
  text-align: center
}

.asis-tree .tree-code-l1,
.tobe-tree .tree-code-l1 {
  font-family: monospace;
  background: var(--main-orange-color);
  color: #fff;
  padding: 3px 9px;
  border-radius: var(--r-sm);
  font-size: 11px;
  font-weight: 700
}

.tobe-tree .tree-code-l1 {
  background: #1F7A4D
}

.asis-tree .tree-code-l2,
.tobe-tree .tree-code-l2 {
  font-family: monospace;
  background: var(--main-cyan-color);
  color: #fff;
  padding: 2px 7px;
  border-radius: 3px;
  font-size: 10.5px;
  font-weight: 700
}

.asis-tree .tree-name-l1,
.tobe-tree .tree-name-l1 {
  font-size: 14px;
  font-weight: 700;
  color: var(--main-orange-color)
}

.tobe-tree .tree-name-l1 {
  color: #1F7A4D
}

.asis-tree .tree-name-l2,
.tobe-tree .tree-name-l2 {
  font-size: 13px;
  font-weight: 600;
  color: var(--text)
}

.asis-tree .tree-meta,
.tobe-tree .tree-meta {
  font-size: 11px;
  color: var(--gray-500);
  font-style: italic
}

.asis-tree .tree-children,
.tobe-tree .tree-children {
  display: none;
  padding-top: 1rem;
  padding-left: 0;
  margin-bottom: 4px
}

.asis-tree .tree-children.open,
.tobe-tree .tree-children.open {
  display: block
}

.asis-tree .tree-info-block,
.tobe-tree .tree-info-block {
  padding: 8px 14px;
  background: var(--gray-50);
  border-left: 3px solid var(--gray-300);
  margin: 4px 0 6px 56px;
  border-radius: 0 var(--r-sm) var(--r-sm) 0;
  line-height: 1.5
}




/* GAP */
.asis-tree .gap-block,
.tobe-tree .gap-block {
  margin: 8px 0 10px 28px;
  padding: 10px 14px;
  background: #fafbfc;
  border: 1px solid var(--main-grey-100);
  border-radius: var(--r-sm);
  display: flex;
  flex-direction: column;
  gap: 5px
}

.asis-tree .gap-line,
.tobe-tree .gap-line {
  font-size: 11.5px;
  line-height: 1.4;
  display: flex;
  align-items: flex-start;
  gap: 7px;
  padding: 5px 8px;
  border-radius: 3px
}

.asis-tree .gap-line i,
.tobe-tree .gap-line i {
  font-size: 11px;
  margin-top: 2px;
  flex-shrink: 0;
  width: 14px;
  text-align: center
}

.asis-tree .gap-line strong,
.tobe-tree .gap-line strong {
  font-weight: 700;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .03em;
  flex-shrink: 0;
  margin-right: 3px
}

.asis-tree .gap-issue,
.tobe-tree .gap-issue {
  background: #fde8ea;
  color: var(--main-red-900);
  border-left: 3px solid var(--main-red-800)
}

.asis-tree .gap-issue i,
.tobe-tree .gap-issue i {
  color: var(--main-red-800)
}

.asis-tree .gap-issue strong,
.tobe-tree .gap-issue strong {
  color: var(--main-red-800)
}

.asis-tree .gap-improve,
.tobe-tree .gap-improve {
  background: #e1f0e8;
  color: var(--main-green-600);
  border-left: 3px solid var(--main-green-900);
}

.asis-tree .gap-improve i,
.tobe-tree .gap-improve i {
  color: var(--main-green-900)
}

.asis-tree .gap-improve strong,
.tobe-tree .gap-improve strong {
  color: var(--main-green-900)
}

.asis-tree .gap-resolved,
.tobe-tree .gap-resolved {
  background: #d1e7dd;
  color: var(--main-green-900);
  border-left: 3px solid var(--main-green-800);
  font-weight: 600
}

.asis-tree .gap-resolved i,
.tobe-tree .gap-resolved i {
  color: var(--main-green-800)
}

.asis-tree .gap-resolved strong,
.tobe-tree .gap-resolved strong {
  color: var(--main-green-800)
}




/* Varianti TO-BE per albero (header verdi al posto di arancio) */
.tobe-row-process{background:linear-gradient(135deg,#e1f0e8 0%,#c8e0d2 100%) !important;border-color:#1F7A4D !important}
.tobe-code-l1{background:#1F7A4D !important}
.tobe-name-l1{color:#0F4A2D !important}
.tobe-row-sub{border-color:#a8d4b8}
.tobe-row-sub:hover{border-color:#1F7A4D !important;background:#e1f0e8 !important}
.tobe-code-l2{background:#1F7A4D !important}
.tobe-info-block{background:#f0f9f4;border-left-color:#1F7A4D}
.tobe-gap-block{background:#f4faf7;border-color:#a8d4b8}




/* ===== INTERVIEW CARD (editable) ===== */
.asis-interview-toolbar {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 14px;
  background: var(--main-grey-50);
  border: 1px solid var(--main-grey-200);
  border-radius: var(--r-md);
  margin-bottom: 14px;
}

.asis-interview-card {
  border: 1px solid var(--main-grey-200);
  border-radius: var(--r-md);
  margin-bottom: 15px;
  overflow: hidden;
  background: #fff;
  transition: var(--tr);
}

.asis-interview-card:hover {
  border-color: var(--main-blue-300);
  box-shadow: var(--shadow-sm);
}

.asis-interview-header {
  background: var(--main-grey-50);
  padding: 10px 15px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  cursor: pointer;
  border-bottom: 1px solid transparent;
}

.asis-interview-card.open .asis-interview-header {
  border-bottom-color: var(--main-grey-200);
}

.asis-interview-title-wrap {
  display: flex;
  align-items: center;
  gap: 10px;
  flex: 1;
}

.asis-interview-num {
  background: var(--main-blue-100);
  color: var(--main-blue-700);
  font-size: 11px;
  font-weight: 700;
  padding: 2px 6px;
  border-radius: 4px;
}

.asis-interview-title {
  font-weight: 600;
  color: var(--main-blue-900);
  font-size: 14px;
}

.asis-interview-body {
  padding: 15px;
  display: none;
}

.asis-interview-card.open .asis-interview-body {
  display: block;
}

.asis-interview-body .row-form {
  display: flex;
  gap: 15px;
  margin-bottom: 15px;
}

.asis-interview-body .row-form .col {
  flex: 1;
}

.asis-interview-body .form-label {
  display: block;
  font-size: 11px;
  font-weight: 700;
  color: var(--main-grey-600);
  margin-bottom: 5px;
  text-transform: uppercase;
}

.asis-interview-body .form-label i {
  margin-right: 4px;
  color: var(--main-blue-500);
}

.asis-interview-list .form-control {
  border-color: var(--main-grey-200);
  font-size: 13px;
}

.asis-interview-list .form-control:focus {
  border-color: var(--main-blue-400);
}

.asis-interview-footer {
  padding: 10px 15px;
  background: var(--main-grey-50);
  border-top: 1px solid var(--main-grey-200);
  text-align: right;
}

/* ===== SUBPROCESS BLOCKS (espandibili) ===== */
/* Pipeline orizzontale macro */
.sp-pipeline{display:flex;align-items:stretch;gap:0;padding:14px 16px;background:linear-gradient(135deg,#fff5eb 0%,#ffe4c4 100%);border:1px solid var(--primary-mid);border-radius:var(--r-md);margin-bottom:14px;flex-wrap:nowrap;overflow-x:auto}
.sp-pipeline.tobe-pipeline{background:linear-gradient(135deg,#e1f0e8 0%,#c8e0d2 100%);border-color:#1F7A4D}
.sp-pipe-step{flex:1;min-width:160px;padding:10px 12px;background:#fff;border:1.5px solid var(--primary);border-radius:var(--r-sm);display:flex;flex-direction:column;justify-content:center;text-align:center;transition:var(--t);cursor:pointer;position:relative}
.tobe-pipeline .sp-pipe-step{border-color:#1F7A4D}
.sp-pipe-step:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}
.sp-pipe-code{font-family:monospace;font-size:10px;font-weight:700;color:var(--primary);margin-bottom:3px}
.tobe-pipeline .sp-pipe-code{color:#1F7A4D}
.sp-pipe-name{font-size:11.5px;font-weight:600;color:var(--text);line-height:1.25}
.sp-pipe-meta{font-size:9.5px;color:var(--gray-500);margin-top:4px}
.sp-pipe-issue{display:inline-block;background:var(--danger);color:#fff;font-size:9px;font-weight:700;padding:1px 5px;border-radius:3px;margin-top:4px;font-family:monospace}
.sp-pipe-issue.fix{background:#1F7A4D}
.sp-pipe-arrow{display:flex;align-items:center;color:var(--primary);font-size:18px;padding:0 6px;flex-shrink:0;font-weight:700}
.tobe-pipeline .sp-pipe-arrow{color:#1F7A4D}

/* Card sottoprocesso espandibile */
.sp-block{border:1.5px solid var(--gray-200);border-radius:var(--r-md);margin-bottom:10px;background:#fff;overflow:hidden;transition:var(--t)}
.sp-block:hover{border-color:var(--primary)}
.sp-block.tobe-block:hover{border-color:#1F7A4D}
.sp-block-header{padding:12px 16px;background:var(--gray-50);display:flex;align-items:center;gap:10px;cursor:pointer;user-select:none;transition:var(--t)}
.sp-block-header:hover{background:var(--primary-light)}
.tobe-block .sp-block-header:hover{background:#e1f0e8}
.sp-block-code{font-family:monospace;background:var(--info);color:#fff;padding:3px 9px;border-radius:var(--r-sm);font-size:11px;font-weight:700;flex-shrink:0}
.tobe-block .sp-block-code{background:#1F7A4D}
.sp-block-title{font-size:13.5px;font-weight:700;color:var(--text)}
.sp-block-meta{margin-left:auto;display:flex;gap:8px;align-items:center;font-size:11px;color:var(--gray-500)}
.sp-block-chev{transition:transform .25s;color:var(--gray-400);font-size:14px}
.sp-block-chev.open{transform:rotate(180deg)}
.sp-block-body{padding:14px 16px;border-top:1px solid var(--gray-200);display:none;background:#fff}
.sp-block-body.open{display:block}

/* Mini-flow dei nodi attività */
.sp-mini-flow{display:flex;align-items:stretch;gap:0;flex-wrap:wrap;padding:8px 0}
.sp-act-node{flex:1;min-width:170px;max-width:240px;padding:10px 12px;border-radius:var(--r-sm);font-size:11px;line-height:1.35;text-align:left;display:flex;flex-direction:column;justify-content:center;position:relative;transition:var(--t)}
.sp-act-node:hover{transform:translateY(-1px);box-shadow:var(--shadow-sm)}
.sp-act-node.tg-planning{background:#E8EEF4;border:1.5px solid #2B5A87;color:#1B3A5A}
.sp-act-node.tg-ts{background:#FFF4DB;border:1.5px solid #B88A1F;color:#5C4612}
.sp-act-node.tg-manual{background:#EDE7DC;border:1.5px dashed #6B5D42;color:#3D3424}
.sp-act-node.tg-bi{background:#E1F0E8;border:2px solid #1F7A4D;color:#0F4A2D;font-weight:600}
.sp-act-node.tg-rf{background:#E1F0E8;border:2px solid #1F7A4D;color:#0F4A2D;font-weight:600}
.sp-act-node.tg-decision{background:#F0E8DC;border:1.5px solid #7A5A1A;color:#4A3810}
.sp-act-code{font-family:monospace;font-size:9px;color:inherit;opacity:.7;margin-bottom:4px;font-weight:700}
.sp-act-title{font-weight:600;font-size:11.5px;margin-bottom:3px;line-height:1.25}
.sp-act-sub{font-size:10px;opacity:.85;line-height:1.3}
.sp-act-warn{font-size:9.5px;color:#A31621;font-style:italic;margin-top:3px;font-weight:600}
.sp-act-tags{margin-top:6px;display:flex;flex-wrap:wrap;gap:3px}
.sp-bug-tag{display:inline-block;background:#A31621;color:#fff;font-size:9px;font-weight:700;padding:2px 5px;border-radius:3px;font-family:monospace}
.sp-bug-tag.fix{background:#1F7A4D}
.sp-bug-tag.warn{background:#B88A1F}
.sp-act-arrow{display:flex;align-items:center;color:var(--gray-400);font-size:18px;padding:0 6px;flex-shrink:0;font-weight:700}
.sp-act-arrow.crit{color:var(--danger)}
.sp-act-arrow.fix{color:#1F7A4D}

/* Issue summary nel sottoprocesso */
.sp-issues-strip{margin-top:10px;padding:8px 12px;background:#FDE8EA;border-left:3px solid var(--danger);font-size:11px;color:#5A0F18;border-radius:0 var(--r-sm) var(--r-sm) 0;line-height:1.5}
.sp-issues-strip.fix{background:#E1F0E8;border-left-color:#1F7A4D;color:#0F4A2D}
.sp-issues-strip strong{color:var(--danger);font-weight:700}
.sp-issues-strip.fix strong{color:#1F7A4D}

/* Espandi/collassa tutti */
.sp-tools-bar{display:flex;gap:8px;align-items:center;padding:8px 0;margin-bottom:8px;font-size:11px;color:var(--gray-500)}

/* ===== SLA TABLE ===== */
.sla-table{width:100%;border-collapse:collapse;font-size:12px}
.sla-table th{background:var(--gray-50);border-bottom:2px solid var(--gray-200);padding:8px 12px;text-align:left;font-weight:700;color:var(--gray-500);font-size:11px;text-transform:uppercase;letter-spacing:.05em}
.sla-table td{padding:9px 12px;border-bottom:1px solid var(--gray-100);vertical-align:middle}
.sla-table tr:nth-child(even) td{background:var(--gray-50)}
.sla-table tr:hover td{background:var(--primary-light)!important;transition:background .12s}

/* ===== PDCA ===== */
.pdca-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.pdca-card{border:1px solid var(--gray-200);border-radius:var(--r-md);padding:12px 14px;transition:var(--t)}
.pdca-card:hover{box-shadow:var(--shadow-sm)}
.pdca-card.plan{border-top:3px solid var(--info)}
.pdca-card.do{border-top:3px solid var(--success)}
.pdca-card.check{border-top:3px solid var(--warning)}
.pdca-card.act{border-top:3px solid var(--primary)}
.pdca-title{font-size:12px;font-weight:700;color:var(--gray-700);margin-bottom:8px;display:flex;align-items:center;justify-content:space-between}

/* ===== WORKFLOW ===== */
.wf-step-wrap{display:flex;flex-direction:column;gap:6px}
.wf-step{display:flex;align-items:flex-start;gap:10px;padding:8px 12px;border-radius:var(--r-md);border:1.5px solid var(--gray-200);transition:var(--t)}
.wf-step.done{background:var(--success-bg);border-color:var(--success-border)}
.wf-step.waiting{background:var(--warning-bg);border-color:#fdd663}
.wf-step.blocked{background:var(--gray-50);border-color:var(--gray-200)}
.wf-icon{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;flex-shrink:0}
.wf-icon.done{background:var(--success);color:#fff}
.wf-icon.waiting{background:var(--warning);color:#fff}
.wf-icon.blocked{background:var(--gray-200);color:var(--gray-500)}
.wf-body{flex:1}
.wf-title{font-size:12px;font-weight:600;margin-bottom:2px}
.wf-meta{font-size:11px;color:var(--gray-500)}

/* ===== CHART BARS ===== */
.chart-bar-group{display:flex;align-items:flex-end;gap:4px;height:80px;padding:0 4px}
.chart-bar{flex:1;border-radius:3px 3px 0 0;min-width:14px;transition:opacity .15s}
.chart-bar:hover{opacity:.75}
.chart-labels{display:flex;gap:4px;margin-top:4px}
.chart-lbl{flex:1;text-align:center;font-size:10px;color:var(--gray-400)}

/* ===== MODAL ===== */
/*
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(15,23,42,.45);z-index:1000;align-items:center;justify-content:center;backdrop-filter:blur(3px)}
.modal-overlay.show{display:flex}
.modal-dialog{background:var(--card);border-radius:var(--r-lg);width:720px;max-width:95vw;max-height:92vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow-lg);animation:modal-in .2s ease}
.modal-dialog.lg{width:920px}
@keyframes modal-in{from{opacity:0;transform:scale(.96) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}
.modal-header{padding:14px 18px;border-bottom:1px solid var(--gray-200);display:flex;align-items:center;justify-content:space-between}
.modal-title{font-size:15px;font-weight:700;color:var(--gray-800);display:flex;align-items:center;gap:8px}
.modal-close{background:none;border:none;font-size:20px;color:var(--gray-400);cursor:pointer;padding:3px 7px;border-radius:var(--r-sm);transition:var(--t);line-height:1}
.modal-close:hover{background:var(--gray-100);color:var(--gray-800)}
.modal-body{padding:18px;background:var(--gray-50);overflow-y:auto;flex:1}
.modal-footer{padding:12px 18px;border-top:1px solid var(--gray-200);background:var(--gray-50);display:flex;justify-content:flex-end;gap:8px}
*/

/* ===== UTILS ===== */
.divider{border:none;border-top:1px solid var(--gray-200);margin:12px 0}
.text-right{text-align:right}
.d-flex{display:flex}
.align-center{align-items:center}
.gap-2{gap:8px}
.mt-2{margin-top:8px}
.mr-auto{margin-right:auto}
/* ===================================================================
   AS-IS RACI MATRIX
   =================================================================== */

.raci-selector-container {
    position: absolute;
    z-index: 1100;
    display: flex;
    align-items: center;
    pointer-events: none;
}

.raci-selector-track {
    display: flex;
    gap: 6px;
    padding: 4px 10px;
    background: rgba(255, 255, 255, 0.95);
    backdrop-filter: blur(4px);
    border: 1px solid var(--gray-200);
    border-radius: 30px;
    box-shadow: 0 4px 15px rgba(0,0,0,0.1);
    pointer-events: auto;
    transform-origin: left center;
    animation: raciBounceIn 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

@keyframes raciBounceIn {
    0% { transform: scale(0.3); opacity: 0; }
    70% { transform: scale(1.1); }
    100% { transform: scale(1); opacity: 1; }
}

.raci-selector-track .raci-badge {
    width: 26px;
    height: 26px;
    font-size: 10px;
    transition: transform 0.2s, box-shadow 0.2s;
}

.raci-selector-track .raci-badge:hover {
    transform: scale(1.3) !important;
    box-shadow: 0 2px 8px rgba(0,0,0,0.15);
    z-index: 2;
}

.raci-badge.active-editing {
    outline: 2px solid var(--primary);
    outline-offset: 2px;
    transform: scale(1.1);
}

/* Specific filters for RACI in AS-IS */
.quick-filter .qf-filter-item {
    margin-right: 8px;
}
.quick-filter .qf-filter-item select {
    height: 28px;
    font-size: 11px;
    padding: 2px 8px;
    border-radius: 20px;
}
