/* ============================================================================
   oraculum-bando-wizard.css — Wizard Comune "Redazione bando assistita"
   Punta di diamante: full-screen focus (navy + alone) come i Copilot focus.
   Namespace `ocw-` (Oraculum Comune Wizard). Solo token di oraculum-tokens.css,
   nessuno stile inline, nessuna utility Tailwind. Caricato per ultimo.
   Fase 0: shell + progress + layout + step + sidebar + footer. Fase 2 espande.
   ========================================================================== */

/* ── Stage focus (navy + alone) ─────────────────────────────────────────── */
.oc-bandi-wizard {
  margin: 0;
  min-height: 100vh;
  color: var(--oc-text);
  /* !important: batte `body { background: ...chiaro... !important }` di oraculum-canvas-d1.css
     (CSS globale ereditato da base.html). Senza, il wizard perde il fondo navy e il testo
     chiaro (titolo, label, checkbox) diventa illeggibile su fondo chiaro. */
  background:
    radial-gradient(ellipse 100% 22% at 50% 0%, rgba(255, 255, 255, 0.16) 0%, transparent 65%),
    radial-gradient(ellipse at 30% 8%, #1F4778 0%, #102742 50%, #0B1F36 100%) !important;
  background-attachment: fixed;
  font-family: "Titillium Web", system-ui, -apple-system, sans-serif;
  display: flex;
  flex-direction: column;
}

/* ── Topbar ─────────────────────────────────────────────────────────────── */
.ocw-topbar {
  position: sticky;
  top: 0;
  z-index: 30;
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 12px 24px;
  background: rgba(8, 18, 42, 0.78);
  backdrop-filter: saturate(140%) blur(8px);
  border-bottom: 1px solid rgba(255, 255, 255, 0.10);
}
.ocw-brand {
  display: flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  color: #fff;
}
.ocw-brand-mark { width: 36px; height: 36px; flex: none; display: block; object-fit: contain; }
.ocw-brand-text { display: flex; flex-direction: column; line-height: 1.1; }
.ocw-brand-title { font-weight: 700; font-size: 14px; letter-spacing: 0.4px; }
.ocw-brand-sub {
  font-family: "Roboto Mono", ui-monospace, SFMono-Regular, Menlo, monospace;
  font-size: 10px; letter-spacing: 0.06em; text-transform: uppercase;
  color: rgba(255, 255, 255, 0.60); margin-top: 1px;
}
.ocw-topbar-spacer { flex: 1; }
.ocw-topbar-step {
  font-family: "Roboto Mono", ui-monospace, SFMono-Regular, Menlo, monospace;
  font-size: 10.5px;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.70);
  font-variant-numeric: tabular-nums;
}
.ocw-exit {
  color: rgba(255, 255, 255, 0.70);
  text-decoration: none;
  font-size: 13px;
  font-weight: 600;
  padding: 8px 12px;
  border-radius: 8px;
  min-height: 44px;
  display: inline-flex;
  align-items: center;
  border: none;
  background: transparent;
}
.ocw-exit:hover { color: #fff; background: rgba(255, 255, 255, 0.08); }

/* ── Progress (12 step) ─────────────────────────────────────────────────── */
.ocw-progress {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 16px 24px 4px;
  max-width: 1180px;
  width: 100%;
  margin: 0 auto;
  overflow-x: auto;
}
.ocw-progress-step {
  flex: 1 1 0;
  min-width: 14px;
  height: 4px;
  border-radius: 2px;
  background: rgba(255, 255, 255, 0.16);
  transition: background 0.18s ease;
}
.ocw-progress-dot,
.ocw-progress-bar { display: none; }
.ocw-progress-step.is-done { background: rgba(255, 255, 255, 0.55); }
.ocw-progress-step.is-current { background: #fff; }

/* ── Stage / card ───────────────────────────────────────────────────────── */
.ocw-stage {
  flex: 1;
  width: 100%;
  max-width: 1180px;
  margin: 0 auto;
  padding: 16px 24px 120px;
}
.ocw-card {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 340px;
  gap: 0;
  background: var(--oc-bg);
  border-radius: 16px;
  box-shadow: 0 24px 60px rgba(8, 18, 42, 0.4);
  overflow: hidden;
  min-height: 60vh;
}
.ocw-main { padding: 32px 36px; min-width: 0; }
.ocw-aside {
  padding: 28px 24px;
  background: var(--oc-bg-2);
  border-left: 1px solid var(--oc-border);
}

/* ── Step ───────────────────────────────────────────────────────────────── */
.ocw-step { display: none; animation: ocw-fade 0.22s ease; }
.ocw-step.active-step { display: block; }
@keyframes ocw-fade { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: none; } }

.ocw-step-eyebrow {
  font-family: "Roboto Mono", ui-monospace, SFMono-Regular, Menlo, monospace;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--oc-accent);
  margin-bottom: 10px;
}
.ocw-step-title {
  font-family: Lora, Georgia, serif;
  font-weight: 500;
  font-size: 30px;
  letter-spacing: -0.01em;
  line-height: 1.25;
  margin: 0 0 10px;
  max-width: 680px;
  color: var(--oc-primary);
}
.ocw-step-sub { font-size: 14.5px; color: var(--oc-text-2); line-height: 1.6; margin: 0 0 24px; max-width: 600px; }
.ocw-step-placeholder {
  margin-top: 16px;
  padding: 24px;
  border: 1.5px dashed var(--oc-border-2);
  border-radius: 12px;
  color: var(--oc-text-3);
  font-size: 14px;
  background: var(--oc-bg-2);
}

/* ── Campi ──────────────────────────────────────────────────────────────── */
.ocw-field { margin-bottom: 16px; }
.ocw-field > label,
.ocw-field-label {
  display: block;
  font-size: 12px;
  font-weight: 600;
  color: var(--oc-text);
  margin-bottom: 6px;
}
.ocw-field-opt { font-weight: 400; color: var(--oc-text-4); }
.ocw-input,
.ocw-textarea,
.ocw-select {
  width: 100%;
  box-sizing: border-box;
  padding: 11px 13px;
  font: inherit;
  font-family: "Titillium Web", "Helvetica Neue", Arial, sans-serif;
  font-size: 13.5px;
  color: var(--oc-text);
  background: var(--oc-bg);
  border: 1.5px solid var(--oc-border-2);
  border-radius: 9px;
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}
.ocw-textarea { min-height: 96px; resize: vertical; line-height: 1.55; }
.ocw-input:focus,
.ocw-textarea:focus,
.ocw-select:focus {
  outline: none;
  border-color: var(--oc-accent);
  box-shadow: 0 0 0 3px var(--oc-accent-light);
}
.ocw-field-hint { font-size: 12.5px; color: var(--oc-text-3); margin-top: 6px; line-height: 1.45; }

/* Chip multi-select (tipo beneficiario, ATECO, ecc.) */
.ocw-chips { display: flex; flex-wrap: wrap; gap: 9px; }
.ocw-chip {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 9px 14px;
  min-height: 40px;
  border-radius: 999px;
  border: 1.5px solid var(--oc-border-2);
  background: var(--oc-bg);
  color: var(--oc-text);
  font-size: 13.5px;
  cursor: pointer;
  user-select: none;
  transition: all 0.15s ease;
}
.ocw-chip:hover { border-color: var(--oc-accent); }
.ocw-chip input { position: absolute; opacity: 0; pointer-events: none; }
.ocw-chip.is-checked {
  background: var(--oc-accent);
  border-color: var(--oc-accent);
  color: #fff;
  font-weight: 600;
}

/* ── Sidebar "Oraculum suggerisce" ──────────────────────────────────────── */
.ocw-aside-head { display: flex; align-items: center; gap: 9px; margin-bottom: 12px; }
.ocw-aside-mark {
  width: 26px; height: 26px; flex: none;
  display: flex; align-items: center; justify-content: center;
  border-radius: 50%;
  font-family: Lora, Georgia, serif;
  font-style: italic;
  font-size: 14px; font-weight: 600;
  color: #fff;
  background: rgba(255, 255, 255, 0.12);
}
.ocw-aside-headtext { display: flex; flex-direction: column; }
.ocw-aside-title { font-size: 12.5px; font-weight: 700; color: var(--oc-primary); letter-spacing: 0.01em; }
.ocw-aside-sub {
  font-family: "Roboto Mono", ui-monospace, SFMono-Regular, Menlo, monospace;
  font-size: 9.5px; letter-spacing: 0.06em; text-transform: uppercase;
  color: rgba(255, 255, 255, 0.55); margin-top: 1px;
}
.ocw-aside-body { font-size: 13px; color: var(--oc-text-2); line-height: 1.6; }
.ocw-aside-body p { margin: 0 0 12px; }
.ocw-aside-body p:last-child { margin-bottom: 0; }
.ocw-aside-loading { display: flex; align-items: center; gap: 9px; color: var(--oc-text-3); font-size: 13px; }
.ocw-spinner {
  width: 15px; height: 15px; flex: none;
  border: 2px solid var(--oc-border-2);
  border-top-color: var(--oc-accent);
  border-radius: 50%;
  animation: ocw-spin 0.7s linear infinite;
}
@keyframes ocw-spin { to { transform: rotate(360deg); } }

/* ── Footer navigazione ─────────────────────────────────────────────────── */
.ocw-footer {
  position: fixed;
  left: 0; right: 0; bottom: 0;
  z-index: 30;
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 24px;
  background: rgba(8, 18, 42, 0.82);
  backdrop-filter: saturate(140%) blur(8px);
  border-top: 1px solid rgba(255, 255, 255, 0.10);
}
.ocw-footer-inner {
  display: flex;
  align-items: center;
  gap: 12px;
  width: 100%;
  max-width: 1180px;
  margin: 0 auto;
}
.ocw-footer-spacer { flex: 1; }
.ocw-save-status { font-size: 12.5px; color: var(--oc-accent-light); min-height: 18px; }

/* ── Bottoni ────────────────────────────────────────────────────────────── */
.ocw-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 44px;
  padding: 0 18px;
  font: inherit;
  font-size: 13.5px;
  font-weight: 600;
  border-radius: 10px;
  border: 1.5px solid transparent;
  cursor: pointer;
  text-decoration: none;
  transition: all 0.15s ease;
}
.ocw-btn:disabled { opacity: 0.45; cursor: not-allowed; }
.ocw-btn-primary {
  color: #fff;
  background: linear-gradient(180deg, #3973B6 0%, #2A5A91 100%);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.20), 0 2px 6px rgba(31, 71, 120, 0.30);
}
.ocw-btn-primary:not(:disabled):hover { background: linear-gradient(180deg, #2A5A91 0%, #1F4778 100%); }
.ocw-btn-ghost {
  color: rgba(255, 255, 255, 0.75);
  background: transparent;
  border-color: rgba(255, 255, 255, 0.20);
}
.ocw-btn-ghost:not(:disabled):hover { background: rgba(255, 255, 255, 0.08); color: #fff; }
.ocw-btn-save {
  color: #fff;
  background: rgba(255, 255, 255, 0.10);
  border-color: rgba(255, 255, 255, 0.20);
}
.ocw-btn-save:not(:disabled):hover { background: rgba(255, 255, 255, 0.16); }
/* Ghost su superficie chiara (anti-pattern, anteprima allegato): testo accent leggibile */
.ocw-ap-item .ocw-btn-ghost,
.ocw-alleg-gen-head .ocw-btn-ghost {
  color: var(--oc-accent); border-color: var(--oc-border-2);
}
.ocw-ap-item .ocw-btn-ghost:not(:disabled):hover,
.ocw-alleg-gen-head .ocw-btn-ghost:not(:disabled):hover {
  background: var(--oc-accent-light); color: var(--oc-accent-dark);
}

/* ── Responsive (desktop-first; degradazione leggibile) ─────────────────── */
@media (max-width: 900px) {
  .ocw-card { grid-template-columns: 1fr; }
  .ocw-aside { border-left: none; border-top: 1px solid var(--oc-border); }
  .ocw-main { padding: 24px 20px; }
  .ocw-step-title { font-size: 23px; }
}
@media (max-width: 600px) {
  .ocw-stage { padding: 12px 12px 130px; }
  .ocw-progress { padding: 12px 12px 4px; }
  .ocw-progress-step .ocw-progress-bar { display: none; }
}

/* ════════════ Fase 2 — widget degli step di raccolta ════════════ */

/* Layout a due colonne per i campi affiancati */
.ocw-row2 { display: grid; grid-template-columns: 1fr 1fr; gap: 0 12px; }
@media (max-width: 560px) { .ocw-row2 { grid-template-columns: 1fr; } }

.ocw-btn-sm { min-height: 38px; padding: 0 14px; font-size: 13.5px; }

/* Validazione inline (voce Letizia) — glass su navy, parità CD .oc-wz-validation */
.ocw-validation { margin-top: 6px; }
.ocw-inline-err, .ocw-inline-warn, .ocw-inline-ok, .ocw-inline-info {
  font-size: 13px; line-height: 1.55; margin: 14px 0 0; padding: 12px 15px;
  border-radius: 7px; border: 1px solid;
}
.ocw-inline-err  { background: rgba(204, 51, 77, 0.16); color: #F6B9C4; border-color: rgba(204, 51, 77, 0.40); }
.ocw-inline-warn { background: rgba(166, 99, 0, 0.14); color: #F4D67A; border-color: rgba(245, 215, 130, 0.40); }
.ocw-inline-ok   { background: rgba(0, 128, 85, 0.16); color: #7FD6B0; border-color: rgba(0, 128, 85, 0.40); }
.ocw-inline-err strong, .ocw-inline-warn strong, .ocw-inline-ok strong, .ocw-inline-info strong { color: #fff; font-weight: 600; }
/* su superficie chiara (box regime): torna a chip leggibile scuro-su-chiaro */
.ocw-regime-box .ocw-inline-warn { background: var(--oc-badge-soon-bg); color: var(--oc-badge-soon-fg); border-color: var(--oc-warning); }
.ocw-regime-box .ocw-inline-err  { background: #FCE8EC; color: #8A1E32; border-color: var(--oc-danger); }
.ocw-regime-box .ocw-inline-ok   { background: var(--oc-badge-open-bg); color: var(--oc-badge-open-fg); border-color: var(--oc-success); }
.ocw-inline-info { background: rgba(255, 255, 255, 0.06); color: rgba(255, 255, 255, 0.82); border-color: rgba(255, 255, 255, 0.18); }
.ocw-regime-box .ocw-inline-info { background: var(--oc-bg-2); color: var(--oc-text-2); border-color: var(--oc-border-2); }

/* Step 2 — card famiglia (parità CD wz2: 2 colonne, gap 12, max 720) */
.ocw-famiglie { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; max-width: 720px; }
.ocw-famiglie .ocw-aside-loading,
.ocw-famiglie .ocw-step-placeholder { grid-column: 1 / -1; }
@media (max-width: 640px) { .ocw-famiglie { grid-template-columns: 1fr; } }
.ocw-fam-card {
  padding: 18px 20px; border: 1.5px solid transparent; border-radius: 10px;
  background: var(--oc-bg); cursor: pointer; transition: all 0.16s ease;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.18);
}
.ocw-fam-card:hover { transform: translateY(-1px); box-shadow: 0 8px 22px rgba(0, 0, 0, 0.24); }
.ocw-fam-card.is-selected { border-color: var(--oc-gold); }
.ocw-fam-name { font-family: Lora, Georgia, serif; font-weight: 600; font-size: 17px; color: var(--oc-text); line-height: 1.3; }
.ocw-fam-desc { font-size: 13px; color: var(--oc-text-2); line-height: 1.5; margin: 6px 0 0; }
.ocw-fam-chips { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 12px; padding-top: 10px; border-top: 1px dashed var(--oc-border); }
.ocw-fam-chip {
  font-family: "Roboto Mono", ui-monospace, SFMono-Regular, Menlo, monospace;
  font-size: 10px; letter-spacing: 0.02em; padding: 2px 8px; border-radius: 10px;
  background: var(--oc-accent-light); color: var(--oc-accent-dark);
  white-space: nowrap; max-width: 100%; overflow: hidden; text-overflow: ellipsis;
}

/* Step 0 — card scelta modello (Adatta / Crea da zero), parità CD wz0 */
.ocw-modello-cards { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; max-width: 680px; }
@media (max-width: 640px) { .ocw-modello-cards { grid-template-columns: 1fr; } }
.ocw-modello-card {
  display: block; width: 100%; text-align: left; font: inherit; text-decoration: none;
  padding: 18px 20px; border: 1.5px solid transparent; border-radius: 10px;
  background: var(--oc-bg); cursor: pointer; transition: all 0.16s ease;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.18);
}
.ocw-modello-card:hover { transform: translateY(-1px); box-shadow: 0 8px 22px rgba(0, 0, 0, 0.24); }
.ocw-modello-card.is-selected { border-color: var(--oc-gold); }
.ocw-modello-card-title { font-family: Lora, Georgia, serif; font-weight: 600; font-size: 17px; color: var(--oc-text); line-height: 1.3; }
.ocw-modello-card-line { font-size: 13px; color: var(--oc-text-2); line-height: 1.5; margin: 6px 0 0; }
.ocw-modello-card-egs { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 12px; padding-top: 10px; border-top: 1px dashed var(--oc-border); }
.ocw-modello-card-egs .ocw-eg {
  font-family: "Roboto Mono", ui-monospace, SFMono-Regular, Menlo, monospace;
  font-size: 10px; letter-spacing: 0.02em; padding: 2px 8px; border-radius: 10px;
  background: var(--oc-accent-light); color: var(--oc-accent-dark); white-space: nowrap;
}
.ocw-modello-banner {
  margin: 0 0 16px; padding: 10px 14px; border-radius: 9px;
  background: var(--oc-accent-light); color: var(--oc-accent-dark); font-size: 13.5px; max-width: 680px;
}

/* Step 5 — griglia ATECO */
.ocw-ateco-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
@media (max-width: 700px) { .ocw-ateco-grid { grid-template-columns: 1fr; } }
.ocw-ateco-item {
  display: flex; align-items: flex-start; gap: 9px; padding: 9px 11px; min-height: 44px;
  border: 1.5px solid var(--oc-border-2); border-radius: 9px; cursor: pointer;
  font-size: 13px; line-height: 1.35; transition: all 0.14s ease;
}
.ocw-ateco-item:hover { border-color: var(--oc-accent); }
.ocw-ateco-item.is-checked { background: var(--oc-accent-light); border-color: var(--oc-accent); }
.ocw-ateco-item input { margin-top: 2px; flex: none; }
.ocw-ateco-code { font-weight: 700; color: var(--oc-accent-dark); flex: none; }
.ocw-ateco-descr { color: var(--oc-text-2); }

/* Step 6 — check inline + box regime */
.ocw-check-inline { display: flex; align-items: center; gap: 9px; font-size: 14px; color: var(--oc-text); margin-bottom: 10px; cursor: pointer; min-height: 30px; }
.ocw-regime-result { margin-top: 16px; }
.ocw-regime-box { padding: 16px 18px; border-radius: 10px; background: var(--oc-bg-2); border: 1px solid var(--oc-border); }
.ocw-regime-tipo { font-weight: 700; text-transform: uppercase; letter-spacing: 0.5px; font-size: 13px; color: var(--oc-accent-dark); }
.ocw-regime-rif { font-family: "Roboto Mono", monospace; font-size: 13px; color: var(--oc-primary); margin: 4px 0 8px; }
.ocw-regime-spieg { font-size: 14px; color: var(--oc-text-2); line-height: 1.55; margin: 0; }

/* Step 7 — radio-card modalità + editor criteri */
.ocw-radio-cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 10px; }
.ocw-radio-card {
  display: flex; align-items: center; gap: 9px; padding: 12px 14px; min-height: 48px;
  border: 1.5px solid var(--oc-border-2); border-radius: 10px; cursor: pointer;
  font-size: 14px; transition: all 0.14s ease;
}
.ocw-radio-card:hover { border-color: var(--oc-accent); }
.ocw-radio-card.is-checked { background: var(--oc-accent-light); border-color: var(--oc-accent); font-weight: 600; }
.ocw-criteri-head { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin: 22px 0 10px; }
.ocw-criteri-list { display: flex; flex-direction: column; gap: 8px; margin-bottom: 10px; }
.ocw-criterio-row { display: grid; grid-template-columns: 1fr 90px 36px; gap: 8px; align-items: center; }
.ocw-crit-del {
  width: 36px; height: 36px; border-radius: 8px; border: 1.5px solid var(--oc-border-2);
  background: var(--oc-bg); color: var(--oc-text-3); font-size: 20px; line-height: 1; cursor: pointer;
}
.ocw-crit-del:hover { border-color: var(--oc-danger); color: var(--oc-danger); }

/* Step 9 — allegati */
.ocw-allegati-list { display: flex; flex-direction: column; gap: 9px; }
.ocw-allegato-item {
  display: flex; align-items: flex-start; gap: 11px; padding: 12px 14px; min-height: 44px;
  border: 1.5px solid var(--oc-border-2); border-radius: 10px; cursor: pointer; transition: all 0.14s ease;
}
.ocw-allegato-item:hover { border-color: var(--oc-accent); }
.ocw-allegato-item.is-checked { background: var(--oc-accent-light); border-color: var(--oc-accent); }
.ocw-allegato-item input { margin-top: 3px; flex: none; }
.ocw-allegato-text { display: flex; flex-direction: column; gap: 2px; }
.ocw-allegato-nome { font-weight: 600; font-size: 14px; color: var(--oc-primary); }
.ocw-allegato-descr { font-size: 12.5px; color: var(--oc-text-3); line-height: 1.4; }

/* Step 9 — modulistica generata */
.ocw-allegati-result { margin-top: 14px; display: flex; flex-direction: column; gap: 8px; }
.ocw-alleg-gen { border: 1px solid var(--oc-border); border-radius: 9px; overflow: hidden; }
.ocw-alleg-gen-head { display: flex; align-items: center; justify-content: space-between; gap: 10px; padding: 10px 14px; background: var(--oc-badge-open-bg); }
.ocw-alleg-gen-nome { font-size: 13.5px; font-weight: 600; color: var(--oc-badge-open-fg); }
.ocw-alleg-preview { margin: 0; padding: 14px 16px; font-family: "Roboto Mono", monospace; font-size: 11.5px;
  line-height: 1.5; color: var(--oc-text-2); background: var(--oc-bg-2); white-space: pre-wrap; max-height: 320px; overflow: auto; }

/* Step 10 — redazione assistita (articoli) — parità CD .oc-art */
.ocw-compose-status { margin: 14px 0; font-size: 13.5px; color: rgba(255, 255, 255, 0.78); }
.ocw-articoli { display: flex; flex-direction: column; gap: 10px; margin-top: 8px; }
.ocw-articolo { border-radius: 8px; padding: 14px 16px; background: var(--oc-bg); box-shadow: 0 2px 10px rgba(0, 0, 0, 0.14); animation: ocw-fade 0.2s ease; }
.ocw-articolo-head { display: flex; align-items: center; gap: 10px; margin-bottom: 7px; }
.ocw-articolo-titolo { font-family: Lora, Georgia, serif; font-weight: 600; font-size: 15px; color: var(--oc-text); flex: 1; }
.ocw-articolo-spin { flex: none; }
.ocw-articolo-badge {
  font-family: "Roboto Mono", ui-monospace, SFMono-Regular, Menlo, monospace;
  font-size: 9px; font-weight: 700; letter-spacing: 0.06em; padding: 2px 6px;
  border-radius: 3px; text-transform: uppercase;
}
.ocw-badge-warn { background: #FFF4D6; color: var(--oc-warning); }
.ocw-articolo-corpo { min-height: 110px; font-size: 13px; line-height: 1.6; color: var(--oc-text-2); font-family: Lora, Georgia, serif; }

/* Step 11 — revisione (anti-pattern + semaforo) */
.ocw-antipattern { display: flex; flex-direction: column; gap: 10px; margin-bottom: 8px; }
.ocw-ap-summary { display: flex; gap: 10px; margin-bottom: 4px; }
.ocw-ap-count { font-size: 12px; font-weight: 700; padding: 4px 10px; border-radius: 999px; }
.ocw-ap-count.ocw-ap-rosso { background: #FCE8EC; color: #8A1E32; }
.ocw-ap-count.ocw-ap-giallo { background: var(--oc-badge-soon-bg); color: var(--oc-badge-soon-fg); }
.ocw-ap-item { display: flex; align-items: flex-start; gap: 12px; justify-content: space-between;
  padding: 13px 15px; border-radius: 8px; background: #fff; box-shadow: 0 2px 10px rgba(0, 0, 0, 0.12); }
.ocw-ap-item::before { content: ""; width: 12px; height: 12px; border-radius: 50%; flex: none; margin-top: 3px; }
.ocw-ap-item.ocw-ap-rosso::before { background: var(--oc-danger); }
.ocw-ap-item.ocw-ap-giallo::before { background: var(--oc-warning); }
.ocw-ap-msg { margin: 0; font-size: 13.5px; line-height: 1.5; color: var(--oc-text); flex: 1; }
.ocw-ap-goto { flex: none; white-space: nowrap; }
.ocw-ap-empty { padding: 32px; border-radius: 10px; text-align: center; background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(0, 128, 85, 0.30); color: #fff; font-size: 14px; line-height: 1.5; }
.ocw-ap-empty strong { color: #fff; }

.ocw-semaforo-title { font-family: Lora, Georgia, serif; font-size: 17px; color: var(--oc-primary); margin: 26px 0 12px; }
.ocw-semaforo { display: flex; flex-direction: column; gap: 8px; }
.ocw-sem-axis { display: grid; grid-template-columns: 16px 120px 1fr; align-items: center; gap: 10px;
  padding: 11px 12px; border: 1px solid rgba(255, 255, 255, 0.12); border-radius: 7px;
  background: rgba(255, 255, 255, 0.06); }
.ocw-sem-dot { width: 14px; height: 14px; border-radius: 50%; }
.ocw-sem-verde .ocw-sem-dot { background: var(--oc-success); box-shadow: 0 0 8px rgba(0, 128, 85, 0.5); }
.ocw-sem-giallo .ocw-sem-dot { background: var(--oc-warning); box-shadow: 0 0 8px rgba(166, 99, 0, 0.5); }
.ocw-sem-rosso .ocw-sem-dot { background: var(--oc-danger); box-shadow: 0 0 8px rgba(204, 51, 77, 0.5); }
.ocw-sem-label {
  font-family: "Roboto Mono", ui-monospace, SFMono-Regular, Menlo, monospace;
  font-weight: 600; font-size: 11px; letter-spacing: 0.04em; text-transform: uppercase;
  color: rgba(255, 255, 255, 0.92);
}
.ocw-sem-ev { font-size: 12.5px; color: rgba(255, 255, 255, 0.65); line-height: 1.4; }
@media (max-width: 560px) { .ocw-sem-axis { grid-template-columns: 16px 1fr; } .ocw-sem-ev { grid-column: 2; } }

/* Step 12 — pubblicazione */
.ocw-riepilogo { margin: 8px 0 18px; }
.ocw-riep-dl { margin: 0; border: 1px solid var(--oc-border); border-radius: 10px; overflow: hidden; }
.ocw-riep-row { display: grid; grid-template-columns: 160px 1fr; gap: 0; border-bottom: 1px solid var(--oc-border); }
.ocw-riep-row:last-child { border-bottom: none; }
.ocw-riep-row dt { padding: 10px 14px; background: var(--oc-bg-2); font-weight: 600; font-size: 13px; color: var(--oc-text-2); margin: 0; }
.ocw-riep-row dd { padding: 10px 14px; margin: 0; font-size: 13.5px; color: var(--oc-text); }
.ocw-disclaimer { margin-top: 16px; font-size: 13px; color: #F4D67A; line-height: 1.55;
  padding: 12px 15px; background: rgba(166, 99, 0, 0.14); border-radius: 7px; border: 1px solid rgba(245, 215, 130, 0.40); }
@media (max-width: 560px) { .ocw-riep-row { grid-template-columns: 1fr; } .ocw-riep-row dt { background: var(--oc-bg-2); } }

/* Sidebar liste valori */
.ocw-aside-ul { margin: 8px 0; padding-left: 18px; font-size: 13px; color: var(--oc-text-2); line-height: 1.7; }
.ocw-aside-foot { font-size: 12px; color: var(--oc-text-3); font-style: italic; margin-top: 10px; }

/* ════════ B3 — Wizard contenuto-su-navy (parità CD WzShell) ════════
   Rimuove la card bianca: il contenuto sta direttamente sul navy. Testo diretto
   chiaro; input e superfici selezionabili/risultato restano bianchi (leggibili);
   aside "Oraculum suggerisce" glassy come il CD oc-wz-aside. */
.ocw-card { background: transparent; box-shadow: none; border-radius: 0; min-height: 0; gap: 28px; }
.ocw-main { padding: 24px 0; color: rgba(255, 255, 255, 0.85); }
.ocw-check-inline { color: rgba(255, 255, 255, 0.9); }
/* superfici bianche: testo scuro esplicito (così il testo ereditato resta leggibile su bianco) */
.ocw-articolo, .ocw-regime-box, .ocw-riep-dl, .ocw-fam-card,
.ocw-modello-card, .ocw-ap-item { color: var(--oc-text); }
.ocw-step-eyebrow { color: #8FB4E8; }
/* titolo bianco su navy (vedi fondo .oc-bandi-wizard con !important): nessuna ombra,
   come il CD — il contrasto è dato dal fondo navy ripristinato */
.ocw-step-title { color: #fff; }
/* il titolo è messo a fuoco da showStep() solo per lo screen-reader (roving focus):
   sopprimi l'anello :focus-visible globale (ambra) — non è un controllo interattivo */
.ocw-step-title:focus, .ocw-step-title:focus-visible { outline: none; }
.ocw-step-sub { color: rgba(255,255,255,0.78); }
.ocw-field > label, .ocw-field-label { color: rgba(255,255,255,0.92); }
.ocw-field-hint { color: rgba(255,255,255,0.6); }
.ocw-semaforo-title { color: #fff; }
.ocw-criteri-head { color: rgba(255,255,255,0.92); }
.ocw-input, .ocw-textarea, .ocw-select { border-color: var(--oc-border); }
/* superfici selezionabili / pannelli risultato: sfondo chiaro per restare leggibili su navy */
.ocw-ateco-item, .ocw-allegato-item, .ocw-radio-card, .ocw-riep-dl { background: var(--oc-bg); }
.ocw-step-placeholder { background: rgba(255,255,255,0.06); border-color: rgba(255,255,255,0.22); color: rgba(255,255,255,0.72); }
/* aside glassy (parità CD oc-wz-aside) */
.ocw-aside { background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.12); border-radius: 10px; padding: 18px; backdrop-filter: blur(10px); align-self: start; }
.ocw-aside-title { color: #fff; }
.ocw-aside-body { color: rgba(255,255,255,0.82); }
.ocw-aside-body strong,
.ocw-aside-body em { color: #fff; font-weight: 600; font-style: normal; }
.ocw-aside-ul { color: rgba(255,255,255,0.78); }
.ocw-aside-foot { color: rgba(255,255,255,0.55); }
.ocw-aside-mark { background: rgba(255,255,255,0.12); color: #fff; }
.ocw-aside-loading { color: rgba(255,255,255,0.7); }
@media (max-width: 900px) {
  .ocw-aside { border-top: 1px solid rgba(255,255,255,0.12); }
}

/* ── Pagina lista bozze (/ente/bandi/redazione/bozze — NON focus) ────────── */
.oc-ente-head-actions { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 16px; }

.ocw-bozze-list { list-style: none; margin: 24px 0 0; padding: 0; display: flex; flex-direction: column; gap: 10px; }
.ocw-bozza-row {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 18px;
  background: var(--oc-bg);
  border: 1px solid var(--oc-border);
  border-radius: 12px;
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}
.ocw-bozza-row:hover { border-color: var(--oc-border-2); box-shadow: 0 2px 10px rgba(8, 18, 42, 0.06); }
.ocw-bozza-main { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 4px; text-decoration: none; color: inherit; }
.ocw-bozza-titolo { font-weight: 600; font-size: 15px; color: var(--oc-primary); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.ocw-bozza-meta { font-size: 12.5px; color: var(--oc-text-3); }
.ocw-bozza-stato {
  align-self: flex-start;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  padding: 3px 9px;
  border-radius: 999px;
  background: var(--oc-badge-soon-bg);
  color: var(--oc-badge-soon-fg);
}
.ocw-bozza-stato--in_revisione { background: var(--oc-badge-fse-bg); color: var(--oc-badge-fse-fg); }
.ocw-bozza-stato--pubblicato { background: var(--oc-badge-open-bg); color: var(--oc-badge-open-fg); }
.ocw-bozza-actions { display: flex; gap: 8px; flex: none; }
@media (max-width: 600px) {
  .ocw-bozza-row { flex-direction: column; align-items: stretch; }
  .ocw-bozza-actions { justify-content: flex-end; }
}
