.op-keti_widget {
  border: 1px solid #d9d9d9;
  padding: 22px 26px;
  max-width: 680px;
  background: #fff;
  font-family: Arial, sans-serif;
}

/* OTSIKKO */
.op-keti_widget h3 {
  margin: 0 0 18px 0;
  font-size: 26px;
}

/* LABEL */
.op-keti_widget label {
  display:block;
  font-size:14px;
  margin-bottom:8px;
}

/* INPUT RIVI */
.op-keti_input-row {
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
}

/* PLUS & MIINUS */
.op-keti_input-row button {
  width:38px;
  height:38px;
  border:1px solid #ccc;
  background:#fff;
  font-size:20px;
  cursor:pointer;

  display:flex;
  align-items:center;
  justify-content:center;
  line-height:1;

  color:#000;
  outline:none;
  box-shadow:none;

  transition: background 0.15s ease, border-color 0.15s ease, color 0.15s ease;
}

/* Hover = pysyy oranssina */
.op-keti_input-row button:hover,
.op-keti_input-row button:focus:hover {
  background:#ff8c00;
  border-color:#ff8c00;
  color:#fff;
}

/* Painalluksen hetki */
.op-keti_input-row button:active {
  background:#ff6f00;
  border-color:#ff6f00;
  color:#fff;
}

/* Fokus ilman hoveria = normaali */
.op-keti_input-row button:focus {
  background:#fff;
  border-color:#ccc;
  color:#000;
  outline:none;
}


/* Klikkauksen jälkeen / fokus-tila */
.op-keti_input-row button:focus {
  background:#fff;
  border-color:#ccc;
  color:#000;
  outline:none;
}


/* INPUT */
.op-keti_input-row input {
  width:160px;
  height:38px;
  border:1px solid #ccc;
  text-align:center;
  font-size:16px;
  -moz-appearance:textfield;
}

.op-keti_input-row input::-webkit-outer-spin-button,
.op-keti_input-row input::-webkit-inner-spin-button {
  -webkit-appearance:none;
  margin:0;
}

/* EURO */
.op-keti_input-row span {
  font-size:16px;
}

/* SLIDER */
#slider {
  width:100%;
  margin:14px 0 18px 0;
  appearance:none;
  height:6px;
  background:#e0e0e0;
  border-radius:4px;
}

/* SLIDER PEUKALO */
#slider::-webkit-slider-thumb {
  appearance:none;
  width:22px;
  height:22px;
  border-radius:50%;
  background:#fff;
  border:2px solid #999;
  cursor:pointer;
}

#slider::-moz-range-thumb {
  width:22px;
  height:22px;
  border-radius:50%;
  background:#fff;
  border:2px solid #999;
  cursor:pointer;
}

/* TULOS + NAPPI */
.op-keti_result-row {
  display:flex;
  justify-content:space-between;
  align-items:center;
  margin-top:6px;
}

.op-keti_result {
  font-size:17px;
}

/* CTA */
.op-keti_button {
  background: #ff6a10; /* Alkuperäinen väri */
  color: #fff;
  border: none;
  padding: 10px 18px;
  font-weight: bold;
  cursor: pointer;
  text-decoration: none;
  transition: background-color 0.3s ease; /* Sulava hover */
  border-radius: 5px; /* Pyöristetyt kulmat */
}

.op-keti_button:hover {
  background: #e55a00; /* Tummempi oranssi hoverissa */
}
