:root{
  --ceo-blue:#04b4f0;
  --ceo-green:#01e1af;
  --ceo-green-dark:#00c79c; /* hover più scuro */
  --ceo-red:#d91f50; /* NON usato nei testi */

  --bg:#ffffff;
  --panel:#f6f8fb;
  --card:#ffffff;
  --border:rgba(15,23,42,.10);
  --text:#0f172a;
  --muted:rgba(15,23,42,.65);

  --shadow:0 12px 28px rgba(15,23,42,.08);
  --radius:22px;

  --green-bg: rgba(1,225,175,.12);
  --green-border: rgba(1,225,175,.55);
  --green-glow: 0 0 0 3px rgba(1,225,175,.18);
}

/* ✅ Reset mirato per evitare stili tema/Elementor (hover rosa, testi bianchi, ecc.) */
#ceo,
#ceo *{
  box-sizing:border-box;
}

#ceo button,
#ceo input,
#ceo summary{
  font-family: inherit;
}

#ceo button{
  appearance:none !important;
  -webkit-appearance:none !important;
  background: none;
  border: none;
  box-shadow: none;
  outline: none;
  color: inherit;
}

/* ✅ Link/label/required: niente rosso */
#ceo a{ color: var(--ceo-green) !important; }
#ceo .req{ color: var(--ceo-green) !important; font-weight:900; }
#ceo h1,#ceo h2,#ceo h3,#ceo h4{ color: var(--text); }

.ceo-wrap{
  max-width:1100px;
  margin:30px auto;
  padding:0 14px;
  font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial;
  color:var(--text);
}

.ceo-card{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow:var(--shadow);
}

.ceo-topbar{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:18px 18px;
  background:linear-gradient(180deg, #ffffff, #fbfdff);
  border-bottom:1px solid var(--border);
}

.ceo-brand{display:flex;flex-direction:column;gap:2px}
.ceo-logo{font-weight:900;letter-spacing:.06em}
.ceo-sub{font-size:12px;color:var(--muted)}

.ceo-progress{
  display:grid;
  grid-template-columns:240px 1fr;
  gap:14px;
  padding:18px;
  background:var(--panel);
  border-bottom:1px solid var(--border);
}

.ceo-stepinfo .big{
  font-size:34px;
  font-weight:900;
  margin:0 8px;
}

.muted{color:var(--muted)}

/* ✅ Navigation steps: accento verde */
.ceo-steps{
  list-style:none;
  margin:0;
  padding:0;
  display:grid;
  gap:10px;
}

.ceo-steps li{
  display:flex;
  align-items:center;
  gap:10px;
  color:rgba(15,23,42,.45);
}

.ceo-steps li.active{color:var(--text)}
.ceo-steps span{
  width:30px;height:30px;border-radius:999px;
  display:flex;align-items:center;justify-content:center;
  background:#ffffff;
  border:1px solid var(--border);
  font-weight:900;
}

.ceo-steps li.active span{
  background:linear-gradient(135deg,var(--ceo-green),#b8f8ea);
  color:#062b23;
  border-color:transparent;
}

.ceo-form{padding:18px;background:var(--card)}
.ceo-step{display:none}
.ceo-step.active{display:block}

.ceo-block{margin:16px 0}
.ceo-label{display:block;margin-bottom:8px;font-weight:900; color:var(--text)}

/* grids */
.ceo-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:10px;
}
.ceo-stack{display:grid;gap:10px}

/* ✅ Step 1 buttons: testi verdi + hover verde scuro (mai bianco invisibile) */
.ceo-choice{
  background:#ffffff !important;
  border:1px solid var(--border) !important;
  color:var(--ceo-green-dark) !important;
  padding:14px !important;
  border-radius:16px !important;
  font-weight:900 !important;
  cursor:pointer !important;
  transition:.15s;
  text-align:center;
}

.ceo-choice:hover{
  border-color:rgba(0,199,156,.55) !important;
  box-shadow:0 0 0 3px rgba(0,199,156,.14) !important;
  transform:translateY(-1px);
  color:var(--ceo-green-dark) !important; /* ✅ evita bianco */
}

.ceo-choice.selected{
  background:rgba(1,225,175,.16) !important;
  border-color:rgba(1,225,175,.80) !important;
  box-shadow:0 0 0 3px rgba(1,225,175,.22) !important;
  color:#06382f !important; /* leggibile su fondo verde chiaro */
}

/* slider row */
.ceo-sliderrow{display:flex;align-items:center;gap:12px}
.ceo-badge{
  background:#ffffff;
  border:1px solid var(--border);
  padding:8px 10px;
  border-radius:12px;
  font-weight:900;
  color:var(--ceo-green-dark);
}
.ceo-help{
  background:#ffffff;
  border:1px solid var(--border);
  padding:12px;
  border-radius:14px;
}

/* inputs */
.ceo-input{
  width:100%;
  background:#ffffff;
  border:1px solid var(--border);
  border-radius:14px;
  padding:12px;
  color:var(--text);
  outline:none;
}
.ceo-input:focus{
  border-color:rgba(1,225,175,.75);
  box-shadow:0 0 0 3px rgba(1,225,175,.18);
}

/* ✅ Step 2 - reparti: testi verdi, hover verde scuro, mai bianco */
.ceo-dept-grid{
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:14px;
  margin-top:14px;
}

.ceo-dept-card{
  text-align:center;
  background:#ffffff !important;
  border:1px solid var(--border) !important;
  border-radius:22px !important;
  padding:20px 18px !important;
  cursor:pointer !important;
  transition:.15s;
  min-height:150px;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:8px;
  color:var(--text) !important;
}

.ceo-dept-card:hover{
  border-color:rgba(0,199,156,.55) !important;
  box-shadow:0 0 0 3px rgba(0,199,156,.14) !important;
  transform:translateY(-1px);
  color:var(--text) !important;
}

.ceo-dept-card.selected{
  background:rgba(1,225,175,.14) !important;
  border-color:rgba(1,225,175,.85) !important;
  box-shadow:0 0 0 3px rgba(1,225,175,.22) !important;
}

.ceo-dept-ic{
  width:52px;height:52px;border-radius:16px;
  display:inline-flex;align-items:center;justify-content:center;
  background:rgba(4,180,240,.10);
  border:1px solid rgba(4,180,240,.18);
  font-size:22px;
  line-height:1;
}

.ceo-dept-title{
  display:block;
  font-weight:950;
  font-size:18px;
  color:var(--ceo-green-dark) !important;
}
.ceo-dept-sub{
  display:block;
  margin-top:2px;
  font-size:12px;
  color:var(--muted) !important;
  text-transform:lowercase;
}

/* ✅ Step 3 Processi: più “aria” tra le sezioni come prima */
#processBlocks{
  display:flex;
  flex-direction:column;
  gap:18px; /* più spazio tra accordion */
  margin-top:16px;
}

.ceo-acc{
  background:#ffffff;
  border:1px solid var(--border);
  border-radius:22px;
  overflow:hidden;
  box-shadow:0 10px 22px rgba(15,23,42,.06);
}

.ceo-acc > summary{list-style:none;}
.ceo-acc > summary::-webkit-details-marker{display:none;}

.ceo-acc-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:18px 18px; /* più padding */
  cursor:pointer;
  background:linear-gradient(180deg,#ffffff,#fbfdff);
}

.ceo-acc[open] .ceo-acc-head{
  background:linear-gradient(180deg, rgba(1,225,175,.14), #ffffff);
  border-bottom:1px solid var(--border);
}

.ceo-acc-left{display:flex;align-items:center;gap:12px}
.ceo-acc-icon{
  width:44px;height:44px;border-radius:14px;
  background:rgba(4,180,240,.10);
  border:1px solid rgba(4,180,240,.18);
  display:flex;align-items:center;justify-content:center;
  font-weight:950;
}

.ceo-acc-title{font-weight:950; color:var(--text)}
.ceo-acc-meta{font-size:12px;color:var(--muted)}
.ceo-acc-meta .selCount{color:var(--ceo-green-dark); font-weight:900;}

.ceo-acc-right{display:flex;align-items:center;gap:14px}

.ceo-people{display:flex;align-items:center;gap:10px;color:var(--muted);font-size:12px}

.ceo-qty{
  display:flex;align-items:center;gap:8px;
  background:#ffffff;
  border:1px solid var(--border);
  border-radius:14px;
  padding:6px 8px;
}

.qty{
  width:34px;height:34px;border-radius:12px;
  border:1px solid var(--border) !important;
  background:#ffffff !important;
  cursor:pointer !important;
  font-weight:950 !important;
  color:var(--ceo-green-dark) !important; /* ✅ testo verde */
}
.qty:hover{
  border-color:rgba(0,199,156,.55) !important;
  box-shadow:0 0 0 3px rgba(0,199,156,.14) !important;
  color:var(--ceo-green-dark) !important;
}

.qtyv{min-width:18px;text-align:center;font-weight:950;color:var(--text)}

.ceo-chevron{
  width:22px;height:22px;border-radius:999px;
  background:rgba(15,23,42,.06);
  position:relative;
}
.ceo-chevron::after{
  content:"";
  position:absolute;
  inset:0;margin:auto;
  width:8px;height:8px;
  border-right:2px solid rgba(15,23,42,.55);
  border-bottom:2px solid rgba(15,23,42,.55);
  transform:rotate(45deg);
  top:5px;
}
.ceo-acc[open] .ceo-chevron::after{transform:rotate(-135deg);top:9px;}

.ceo-acc-body{
  padding:16px 18px 18px; /* più aria */
  background:var(--panel);
}

/* checkbox grid “pulito” */
.ceo-checkgrid{
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:12px 16px;
}

.ceo-check{
  display:flex;
  align-items:center;
  gap:10px;
  padding:12px 14px;
  border-radius:16px;
  border:1px solid var(--border);
  background:#ffffff;
  cursor:pointer;
  transition:.12s;
  color:var(--text);
}

.ceo-check input{
  width:18px;height:18px;
  accent-color: var(--ceo-green);
}

.ceo-check:hover{
  border-color:rgba(0,199,156,.45);
  box-shadow:0 0 0 3px rgba(0,199,156,.12);
  color:var(--text);
}

.ceo-check.is-checked{
  background:rgba(1,225,175,.16);
  border-color:rgba(1,225,175,.85);
  box-shadow:0 0 0 3px rgba(1,225,175,.22);
}

/* ✅ Step 4 parametri: resto come già fatto (dark card), ma nessun testo rosso */
.ceo-param-card{
  background:#0b1220;
  color:#eaf0ff;
  border-radius:22px;
  padding:18px 18px;
  border:1px solid rgba(255,255,255,.08);
  box-shadow:0 18px 40px rgba(15,23,42,.18);
  max-width:720px;
}

.ceo-param-row{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:14px;
  margin-bottom:10px;
}

.ceo-param-title{font-weight:950;font-size:16px}
.ceo-param-sub{opacity:.7;font-size:12px;margin-top:2px}
.ceo-param-value{font-weight:950;font-size:20px;color:var(--ceo-blue)}
.ceo-param-title .req{color:var(--ceo-green) !important;}

.ceo-param-card input[type=range]{
  width:100%;
  margin:10px 0 8px;
  accent-color: var(--ceo-blue);
}

.ceo-param-pill{
  display:inline-block;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.10);
  padding:10px 12px;
  border-radius:14px;
  font-weight:700;
  font-size:13px;
  opacity:.95;
}

.ceo-sep{
  border:0;
  height:1px;
  background:rgba(255,255,255,.10);
  margin:16px 0;
}

/* STEP 5 */
.ceo-done{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.ceo-done-ic{
  width:40px;height:40px;border-radius:999px;
  background:rgba(1,225,175,.16);
  border:1px solid rgba(1,225,175,.30);
  display:flex;align-items:center;justify-content:center;
  font-weight:950;color:#0b3b33;
}

.ceo-lead-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px 14px;
  margin-top:10px;
}
.ceo-span-2{grid-column:span 2}

.ceo-cta{
  width:100%;
  border:none;
  margin-top:14px;
  padding:16px 16px;
  border-radius:18px;
  cursor:pointer;
  font-weight:950;
  color:#062b23;
  background:linear-gradient(135deg, var(--ceo-green), #b8f8ea);
  box-shadow:0 14px 26px rgba(1,225,175,.18);
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
}
.ceo-cta:hover{
  background:linear-gradient(135deg, var(--ceo-green-dark), #9ff3df);
}
.ceo-cta.loading{opacity:.7;cursor:not-allowed}

.ceo-privacy{font-size:12px;margin-top:10px;text-align:center}

.ceo-summary{
  margin-top:14px;
  background:var(--panel);
  border:1px solid var(--border);
  border-radius:18px;
  padding:14px;
}
.ceo-summary h3{ color: var(--ceo-green-dark); }

.sumrow{padding:7px 0;border-bottom:1px solid rgba(15,23,42,.08)}
.sumrow:last-child{border-bottom:none}

/* bottoni nav: niente rosso, hover verde scuro */
.ceo-actions{
  display:flex;
  justify-content:space-between;
  gap:12px;
  margin-top:14px;
}

.ceo-btn{
  background:linear-gradient(135deg,var(--ceo-blue),#2a7cff) !important;
  border:none !important;
  color:white !important;
  padding:12px 18px;
  border-radius:16px;
  font-weight:950;
  cursor:pointer;
  width:180px;
  box-shadow:0 10px 18px rgba(4,180,240,.16);
}

.ceo-btn:hover{
  background:linear-gradient(135deg,var(--ceo-green-dark),#9ff3df) !important;
  color:#062b23 !important;
  box-shadow:0 12px 22px rgba(0,199,156,.18) !important;
}

.ceo-btn.ghost{
  background:transparent !important;
  border:1px solid rgba(15,23,42,.16) !important;
  color:var(--ceo-green-dark) !important;
  box-shadow:none !important;
}
.ceo-btn.ghost:hover{
  border-color:rgba(0,199,156,.55) !important;
  box-shadow:0 0 0 3px rgba(0,199,156,.12) !important;
  color:var(--ceo-green-dark) !important;
}

.ceo-btn:disabled{opacity:.5;cursor:not-allowed}

/* toast */
.ceo-toast{
  position:fixed;
  left:50%;
  bottom:18px;
  transform:translateX(-50%);
  background:#ffffff;
  border:1px solid var(--border);
  padding:12px 14px;
  border-radius:16px;
  opacity:0;
  pointer-events:none;
  transition:.2s;
  color:var(--text);
  max-width:92vw;
  box-shadow:0 12px 26px rgba(15,23,42,.12);
}
.ceo-toast.show{opacity:1}
.ceo-toast.ok{border-color:rgba(1,225,175,.45)}
.ceo-toast.err{border-color:rgba(15,23,42,.18)} /* niente rosso */

@media (max-width:900px){
  .ceo-progress{grid-template-columns:1fr}
  .ceo-grid{grid-template-columns:repeat(2,1fr)}
  .ceo-dept-grid{grid-template-columns:1fr}
  .ceo-checkgrid{grid-template-columns:1fr}
  .ceo-lead-grid{grid-template-columns:1fr}
  .ceo-span-2{grid-column:auto}
}

@media (max-width:520px){
  .ceo-btn{width:100%}
  .ceo-actions{flex-direction:column}
  .ceo-people-label{display:none}
}