/* PIN modal container (separat, da eigenes Markup: #modalPin) */
#modalPin{
  position:fixed;
  inset:0;
  display:none;              /* via JS */
  justify-content:center;
  align-items:center;
  z-index:9999;
  background:rgba(0,0,0,.45);
}

#modalPin .modal{
  width:300px;
  padding:20px;
  border-radius:15px;
  box-shadow:0 10px 25px rgba(0,0,0,.5);
}

/* Dots */
.pin-dot-container{
  display:flex;
  justify-content:center;
  align-items:center;
  margin:15px 0;
}
.dot-group{ display:flex; gap:8px; }

.dot{
  width:15px;
  height:15px;
  border:2px solid #ddd;
  border-radius:50%;
  background:transparent;
}
.dot.on{
  background:#2563eb;
  border-color:#2563eb;
}

/* Keypad */
.pinpad{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:12px;
  margin-bottom:20px;
}

.pinpad button{
  height:65px;
  font-size:28px;
  border-radius:10px;
  border:1px solid #e2e8f0;
  background:#f8fafc;
  font-weight:900;
  color:#1e293b;
  cursor:pointer;
  touch-action:manipulation;
}
.pinpad button:active{ background:#cbd5e1; }

.btn-secondary{
  padding:10px 20px;
  border-radius:8px;
  border:none;
  background:#64748b;
  color:#fff;
  cursor:pointer;
}
